两台2005,一台 Server1 :SQL_Latin1_General_CP1_CI_AS一台Server2 :Chinese_PRC_CI_AS
在Server2里的一个varchar字段里有中文能正常显示,但到server1用linkServer取前面varchar字段里的值是中文就是乱码,改成nvarchar就可以了是什么原因,或者能请将以下varchar里的中文和nvarchar里的中文有什么区别,跟collation又有什么关系呢
在Server2里的一个varchar字段里有中文能正常显示,但到server1用linkServer取前面varchar字段里的值是中文就是乱码,改成nvarchar就可以了是什么原因,或者能请将以下varchar里的中文和nvarchar里的中文有什么区别,跟collation又有什么关系呢
解决方案 »
- SQL Like 查询语句
- 有一字段为身份证号码,能否用SQL语句检索其中出生年月字段小与当前日期的查询语句
- MSSQL游标的问题
- SQL Server 2005 变量赋值问题!!!
- SQL SERVER 2000 因为更改了系统(WIN 2000 SERVER)的密码,无法启动。在线等!~~~~
- 写存储过程遇到的问题
- 怎么查看一张表的大小(占的字节数)
- 还原数据的问题
- 我是2000年毕业的,刚毕业时,我VB,ASP,SQL SERVER水平都一般,还会一点DELHIP,后来我工作了,只要是用ASP的
- 如何将我的数据库中 部分的字断 数据 以表格的形式 写入一个文件。
- 动态SQL出错!
- 不能附加数据库文件,总是提示5105错误。
create table a (name1 varchar(8))
insert a select '张红a'
--- 存储长度为5个字节
insert a select '王一南'
----存储长度为6个字节---意思是varchar变长字符数据类型与存储数据的实际长度是一致的 nvarchar(n):可变长度 Unicode 数据,其最大长度为 4,000 字符。
字节的存储大小是所输入字符个数的两倍,
就是说它是双字节来存储数据的。
如果存储数据如果存在单字节时,它也是以双字节来占用存储空间的。 举个例子:
create table aa (name1 nvarchar(8))
insert aa select '张红a'
--- 存储长度为6个字节
N'string' 表示string是个Unicode字符串
含有汉字的使用nvarchar,因为nvarchar是使用Unicode编码,即统一的字符编码标准,会减少乱码的出现几率;
►如果你做的项目可能涉及不同语言之间的转换,建议用nvarchar。这点要注意:varchar 适合与存储英文和数字;
nvarchr一般用于存储中文或其他语言的输入,因为 这样,可以防止到其他语言平台上出现乱码的问题。