varchar里的中文 和nvarchar里的中文

Ray_Zhang 2009-08-17 12:30:17
两台2005,一台 Server1 :SQL_Latin1_General_CP1_CI_AS一台Server2 :Chinese_PRC_CI_AS
在Server2里的一个varchar字段里有中文能正常显示,但到server1用linkServer取前面varchar字段里的值是中文就是乱码,改成nvarchar就可以了是什么原因,或者能请将以下varchar里的中文和nvarchar里的中文有什么区别,跟collation又有什么关系呢
...全文
378 7 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
sharon8259 2009-08-17
  • 打赏
  • 举报
回复
#2楼的解释很详细。
叶子 2009-08-17
  • 打赏
  • 举报
回复
处理乱码用nvarchar就应该可以了。
SQL77 2009-08-17
  • 打赏
  • 举报
回复
VARCHAR里面的中文可能是乱码,

NVARCHAR不会
feixianxxx 2009-08-17
  • 打赏
  • 举报
回复
► 在使用上,如果存储内容都是英文字符而没有汉字等其他语言符号,建议使用varchar;
含有汉字的使用nvarchar,因为nvarchar是使用Unicode编码,即统一的字符编码标准,会减少乱码的出现几率;
►如果你做的项目可能涉及不同语言之间的转换,建议用nvarchar。

这点要注意:varchar 适合与存储英文和数字;
nvarchr一般用于存储中文或其他语言的输入,因为 这样,可以防止到其他语言平台上出现乱码的问题。
水族杰纶 2009-08-17
  • 打赏
  • 举报
回复
N 代表存入数据库时以 Unicode 格式存储。
N'string' 表示string是个Unicode字符串
feixianxxx 2009-08-17
  • 打赏
  • 举报
回复
1、各自的定义:

► nvarchar(n) : 包含 n 个字符的可变长度 Unicode 字符数据。n 的值必须介于 1 与 4,000 之间。字节的存储大小是所输入字符个数的两倍。所输入的数据字符长度可以为零。

► varchar[(n)]: 长度为 n 个字节的可变长度且非 Unicode 的字符数据。n 必须是一个介于 1 和 8,000 之间的数值。存储大小为输入数据的字节的实际长度,而不是 n 个字节。所输入的数据字符长度可以为零。

varchar(max)最大2gb字符 使用C#中的DbType.varchar 针对max DbType.varchar,-1

2、区别:

► 从存储方式上,nvarchar是按字符存储的,而 varchar是按字节存储的;

► 从存储量上考虑, varchar比较节省空间,因为存储大小为字节的实际长度,而 nvarchar是双字节存储;

► 在使用上,如果存储内容都是英文字符而没有汉字等其他语言符号,建议使用varchar;含有汉字的使用nvarchar,因为nvarchar是使用Unicode编码,即统一的字符编码标准,会减少乱码的出现几率;

►如果你做的项目可能涉及不同语言之间的转换,建议用nvarchar。

这点要注意:varchar 适合与存储英文和数字; nvarchr一般用于存储中文或其他语言的输入,因为 这样,可以防止到其他语言平台上出现乱码的问题。

举个例子:
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个字节
水族杰纶 2009-08-17
  • 打赏
  • 举报
回复
unicode編碼

34,837

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧