修改SQL Server 的排序规则(转)
2015-12-03 18:59
465 查看
转自http://jimshu.blog.51cto.com/3171847/1095780/
一、修改SQL Server服务器(实例)的排序规则
以下实验使用了SQL Server 2008 R2的默认实例,将Chinese_PRC_CI_AS修改成SQL_Latin1_General_CP1_CI_AS。
1. 停止SQL Server实例服务
2. 打开“命令提示符”,转到SQL Server的安装目录
3. 运行setup
4. 启动SQL Server实例服务
5. 验证实例的排序规则
6. 验证系统数据库(master、model、msdb、tempdb)的排序规则
说明:此操作仅影响系统数据库。对于已经存在的用户数据库无效。
二、修改数据库的排序规则
以下实验将修改数据库db01的排序规则,将SQL_Latin1_General_CP1_CI_AS修改成Chinese_PRC_CI_AS。
1. SSMS图形界面
2. 脚本
3. 局限性
(1)对于已经存在的数据,此操作并不会导致立即重新排序。
(2)如果已经有对象依赖于数据库排序规则,则更改不成功。
三、修改表的排序规则
表的排序规则依赖于数据库的排序规则。不能修改。
四、修改列的排序规则
建议:将这个表的数据保存到另一个临时表,重建这个表,然后从临时表将数据导入到新表。
可以通过SSMS修改某一列的排序规则,但是,这项操作实际上还是删除这个表以及相关的约束、触发器,然后重建这个表、约束、索引、触发器。
一、修改SQL Server服务器(实例)的排序规则
以下实验使用了SQL Server 2008 R2的默认实例,将Chinese_PRC_CI_AS修改成SQL_Latin1_General_CP1_CI_AS。
1. 停止SQL Server实例服务
2. 打开“命令提示符”,转到SQL Server的安装目录
C:\Users\Administrator> cd "\Program Files\Microsoft SQL Server\100\Setup Bootstrap\SQLServer2008R2" |
C:\Program FIles\Microsoft SQL Server\100\Setup Bootstrap\SQLServer2008R2> setup /QUIET /ACTION=REBUILDDATABASE /instancename=mssqlserver /SQLSYSADMINACCOUNTS=administrator /sqlcollation=SQL_Latin1_General_CP1_CI_AS |
5. 验证实例的排序规则
6. 验证系统数据库(master、model、msdb、tempdb)的排序规则
说明:此操作仅影响系统数据库。对于已经存在的用户数据库无效。
二、修改数据库的排序规则
以下实验将修改数据库db01的排序规则,将SQL_Latin1_General_CP1_CI_AS修改成Chinese_PRC_CI_AS。
1. SSMS图形界面
2. 脚本
ALTER DATABASE [db01] COLLATE Chinese_PRC_CI_AS |
(1)对于已经存在的数据,此操作并不会导致立即重新排序。
(2)如果已经有对象依赖于数据库排序规则,则更改不成功。
三、修改表的排序规则
表的排序规则依赖于数据库的排序规则。不能修改。
四、修改列的排序规则
建议:将这个表的数据保存到另一个临时表,重建这个表,然后从临时表将数据导入到新表。
可以通过SSMS修改某一列的排序规则,但是,这项操作实际上还是删除这个表以及相关的约束、触发器,然后重建这个表、约束、索引、触发器。
ALTER TABLE dbo.EmpBasic DROP CONSTRAINT DF__EmpBasic__FirstN__2319CD4B ALTER TABLE dbo.EmpBasic DROP CONSTRAINT ...... CREATE TABLE dbo.Tmp_EmpBasic ( ...... FirstName nvarchar(30) COLLATE Chinese_PRC_CI_AS NULL, ...... ) ON [PRIMARY] ALTER TABLE dbo.Tmp_EmpBasic SET (LOCK_ESCALATION = TABLE) GRANT DELETE ON dbo.Tmp_EmpBasic TO public AS dbo GRANT INSERT ON dbo.Tmp_EmpBasic TO public AS dbo GRANT SELECT ON dbo.Tmp_EmpBasic TO public AS dbo GRANT UPDATE ON dbo.Tmp_EmpBasic TO public AS dbo ALTER TABLE dbo.Tmp_EmpBasic ADD CONSTRAINT DF__EmpBasic__FirstN__2319CD4B DEFAULT ('') FOR FirstName ALTER TABLE dbo.Tmp_EmpBasic ADD CONSTRAINT DF__EmpBasic__Middle__240DF184 ...... SET IDENTITY_INSERT dbo.Tmp_EmpBasic ON IF EXISTS(SELECT * FROM dbo.EmpBasic) EXEC('INSERT INTO dbo.Tmp_EmpBasic (Company, EmpID, FirstName,......) SELECT Company, EmpID, FirstName, ...... FROM dbo.EmpBasic WITH (HOLDLOCK TABLOCKX)') SET IDENTITY_INSERT dbo.Tmp_EmpBasic OFF DROP TABLE dbo.EmpBasic EXECUTE sp_rename N'dbo.Tmp_EmpBasic', N'EmpBasic', 'OBJECT' CREATE UNIQUE CLUSTERED INDEX EmpID ON dbo.EmpBasic (Company, EmpID ) WITH( STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = OFF) ON [PRIMARY] CREATE NONCLUSTERED INDEX FirstName ON dbo.EmpBasic ( Company, FirstName, LastName ) WITH( STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = OFF) ON [PRIMARY] create trigger _ti_EmpBasic ON dbo.EmpBasic for insert as begin ...... end |
相关文章推荐
- springmvc+mybatis+spring 整合 bootstrap html5 mysql oracle SSM框架源码 SSH maven
- win7下用VC6.0连接MySQL5.1数据库
- 帮个忙改个sql错误我实在是找不到哪里错了
- sql server 中and 和or
- Oracle 学习之:ASCII,CHR函数的作用和用法
- 链接数据库的问题
- Sql Server xml 类型字段的增删改查
- kali攻防第7章补充 SQLMAP介绍之Cookie注入
- [转]MySQL 清空慢查询文件
- mysql 主重复制过程
- 存储过程分页Sql语句
- Mysql存储过程和函数
- 直接通过SQL能查到,通过HSQL查询不到问题解决
- Centos6.5 安装Redis2.6.16
- MYSQL重装问题解决
- MySQL 升级的最佳实践
- 解决没有my.ini配置文件MySql Error Code: 2006 – MySQL 服务器已离线错误
- mysql 分区 -
- SQL语法常用积累
- 数据库架构、角色、用户、权限集合