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

我正在尝试在单个排序规则上标准化所有数据库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数据(观看整理)>添加约束

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 'EastRiver' 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...