使用SQL database Migration wizard迁移数据库时的varchar中文乱码问题
2013-03-25 16:35
621 查看
最近遇到一个问题,是有一个SQL数据库的表用varchar存中文数据。在使用SQL Migration wizard迁移到Azure后,所有的中文都变成????了。但如果源表是nvarchar类型,则没有问题。
经过分析后,发现该问题的出现跟OS的文本编码有关。
首先,采用varchar存放中文数据并不推荐。SQL server存放varchar数据时,对英文采用1个字节存储,对其他语言采用2个字节存储。而且,存储其他语言(如中文)时,其编码方式是随意的。用户可以输入任何编码方式的字符进入该字段。而SQL server只是在数据库一级通过collation这个属性来标识数据库的语言信息。本例的collation是Chinese_RPC_CI_AS
如果用户写入数据时采用的编码和读出时采用的编码不同,就会导致乱码。因此,建议的方式是采用nvarchar来存储中文数据。nvarchar和varchar的区别是,其编码方式固定采用unicode. 这样就避免了编码不一致的问题
但是,如果已有数据库已经采用了varchar,又不想转换为nvarchar,该怎么办呢?我们在使用SQL database migration wizard时需要注意几个地方:
1. 运行SQL database migration wizard的机器最好安装了中文包,而且必须配置非Unicode编码方式为中文。要注意,Azure上VM的缺省编码方式是英语,所以一定要修改
这样,当SQL database migration wizard把数据从源数据库导出时,就知道该采用哪种编码写入数据文件。
2. 目标SQL Azure数据库在创建时,必须采用跟源数据库一样的collation
这样就可以解决中文字符乱码的问题了
经过分析后,发现该问题的出现跟OS的文本编码有关。
首先,采用varchar存放中文数据并不推荐。SQL server存放varchar数据时,对英文采用1个字节存储,对其他语言采用2个字节存储。而且,存储其他语言(如中文)时,其编码方式是随意的。用户可以输入任何编码方式的字符进入该字段。而SQL server只是在数据库一级通过collation这个属性来标识数据库的语言信息。本例的collation是Chinese_RPC_CI_AS
如果用户写入数据时采用的编码和读出时采用的编码不同,就会导致乱码。因此,建议的方式是采用nvarchar来存储中文数据。nvarchar和varchar的区别是,其编码方式固定采用unicode. 这样就避免了编码不一致的问题
但是,如果已有数据库已经采用了varchar,又不想转换为nvarchar,该怎么办呢?我们在使用SQL database migration wizard时需要注意几个地方:
1. 运行SQL database migration wizard的机器最好安装了中文包,而且必须配置非Unicode编码方式为中文。要注意,Azure上VM的缺省编码方式是英语,所以一定要修改
这样,当SQL database migration wizard把数据从源数据库导出时,就知道该采用哪种编码写入数据文件。
2. 目标SQL Azure数据库在创建时,必须采用跟源数据库一样的collation
这样就可以解决中文字符乱码的问题了
相关文章推荐
- 使用SQL Database Migration Wizard把SQL Server 2008迁移到Windows Azure SQL Database
- red hat下使用oracle instant client的occi接口读写数据库中文乱码问题
- pL/sql Deloper 安装后, 连接数据库,中文乱码问题
- 解决pl/sql devloper 中数据库操作语句中文乱码的问题
- 使用SSMS 2014将本地数据库迁移到Azure SQL Database
- 使用Microsoft SQL Server Database Publishing Wizard生成数据库脚本
- 解决使用secureCRT操作数据库时出现中文乱码问题
- 关于SQL的char,varchar字段在导出时切断中文字符显示问号或乱码的问题[原创]
- Orcale 数据库客户端PL/SQL中文乱码的问题
- mysql使用sql导入数据中文乱码问题
- 解决pl/sql developer中数据库表中显示中文乱码问题
- 使用linux客户端执行shell脚本创建数据库初始化数据库中文乱码问题
- PL/sql developer连接数据库的问题以及oracle数据库中文乱码的问题
- 将现有的sql脚本导入 Oracle 数据库,中文乱码问题
- Orcale 数据库客户端PL/SQL 中文乱码的问题解决方法
- Orcale 数据库客户端PL/SQL 中文乱码的问题
- python使用SQL语句操作数据库中文乱码的解决
- SQL Server Varchar类型字段中文乱码问题的解决
- 解决pl/sql developer中数据库表中显示中文乱码问题
- python使用MySQLdb写数据库时中文乱码问题