加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

sql-server – 如何更改SQL Server数据库的排序规则?

发布时间:2020-12-12 16:55:24 所属栏目:MsSql教程 来源:网络整理
导读:我正在尝试在单个排序规则上标准化所有数据库 – Latin1_General_CI_AS(标准排序规则).我有一些SQL_Latin1_General_CP1_CI_AS中的数据库. 我知道我可以使用ALTER DATABASE来更改数据库排序规则,但这只会影响新对象.我的理解是,更改现有列的唯一方法是在每个表
我正在尝试在单个排序规则上标准化所有数据库 – Latin1_General_CI_AS(标准排序规则).我有一些SQL_Latin1_General_CP1_CI_AS中的数据库.

我知道我可以使用ALTER DATABASE来更改数据库排序规则,但这只会影响新对象.我的理解是,更改现有列的唯一方法是在每个表的每一列上执行ALTER COLUMN – 我需要删除并重新创建所有索引以执行此操作.

我猜它看起来像这样:

DROP INDEX indexname ON tablename

GO

ALTER TABLE tablename ALTER COLUMN columname varchar(50) COLLATE Latin1_General_CI_AS NULL

GO

CREATE CLUSTERED INDEX indexname ON tablename (columname ASC)

并重复整个数据库中的每个varchar,char,text,nvarchar,nchar和ntext列.这将是一个庞大的SQL脚本.

有没有更简单的方法来做到这一点,或者任何人都可以建议一种方法来自动创建SQL脚本来做到这一点?

解决方法

MS KB 325335提供了有关如何为整个数据库和所有列执行此操作的选项.

基本上:

>脚本数据库表(使用新的排序规则)> DTS / SSIS数据(观看整理)>添加约束

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读