SQL 字段类型问题 对于可变长的字段,其类型用 varchar还是nvarchar 好??? 为什么 ??? 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 如果是开发软件,建议用nvarchar,因为nvarchar在各种排序下不会出现乱码.参考一下两者的区别.varchar与nvarchar区别1.varchar[(n)] 长度为 n 个字节的可变长度且非 Unicode 的字符数据。n 必须是一个介于 1 和 8,000 之间的数值。存储大小为输入数据的字节的实际长度,而不是 n 个字节。所输入的数据字符长度可以为零。varchar 在 SQL-92 中的同义词为 char varying 或 character varying。 nvarchar(n) 包含 n 个字符的可变长度 Unicode 字符数据。n 的值必须介于 1 与 4,000 之间。字节的存储大小是所输入字符个数的两倍。所输入的数据字符长度可以为零。nvarchar 在 SQL-92 中的同义词为 national char varying 和 national character varying。 n 表示字符个数nvarchar: 不管是一个字符还是一个汉字,都存为2个字节 varchar: 汉字是2个字节,其他字符存为1个字节 通俗一點就是varchar適合輸入英文和數字,nvarchar一般用做中文或其它語言的輸入,這樣到別的語系不會出現亂碼:))2.N表示Unicode常量,可以解决多语言字符集之间的转换问题,见联机帮助姓名,和房间通常都是用varchar这个数据类型 解释一下: drop proc a varchar(n):变长型字符数据类型,存储最长长度为8,000 个字符。 举个例子: create table a (name1 varchar(8)) insert a select '张红a' --- 存储长度为5个字节,余下的3个字节全部释放 insert a select '王一南' ----存储长度为6个字节,余下的2个字节全部释放 ---意思是varchar变长字符数据类型与存储数据的实际长度是一致的 nvarchar(n):可变长度 Unicode 数据,其最大长度为 4,000 字符。 字节的存储大小是所输入字符个数的两倍, 就是说它是双字节来存储数据的。 如果存储数据如果存在单字节时,它也是以双字节来占用存储空间的。 举个例子: create table aa (name1 nvarchar(8)) insert aa select '张红a' --- 存储长度为6个字节,余下的2个字节全部释放 --nvarchar是unicode编码--可以防止乱码declare @s nvarchar(10)declare @h varchar(10)set @s=N'帳號' set @h='帳號'select @s,@h/*---------- ----------帳號 ??(1 行受影响)*/ varchar[(n)] 长度为 n 个字节的可变长度且非 Unicode 的字符数据。n 必须是一个介于 1 和 8,000 之间的数值。存储大小为输入数据的字节的实际长度,而不是 n 个字节。所输入的数据字符长度可以为零。varchar 在 SQL-92 中的同义词为 char varying 或 character varying。 nvarchar(n) 包含 n 个字符的可变长度 Unicode 字符数据。n 的值必须介于 1 与 4,000 之间。字节的存储大小是所输入字符个数的两倍。所输入的数据字符长度可以为零。nvarchar 在 SQL-92 中的同义词为 national char varying 和 national character varying。 varchar[(n)] 有多种语言符号的话,选择nvarchar SQL日期按月分组,没有某月时也要显示出来,怎么做? 问一个不是问题的问题,关于sql server 2000中message信息。 [急]SQL达人入! 用DTS把表从SQL导向Oracle提示内部错误的问题? insert 多值插入? ''和NULL的问题 Key(resource)知道,但是如何查看对应的记录? 求一个SQL语句,以前没碰到过 为什么不让我修改表的字段的数据类型。 vb 怎样连接sql sever2000 关于SQL SERVER2005中标识列的问题? SQL安装问题
varchar与nvarchar区别
1.
varchar[(n)]
长度为 n 个字节的可变长度且非 Unicode 的字符数据。n 必须是一个介于 1 和 8,000 之间的数值。存储大小为输入数据的字节的实际长度,而不是 n 个字节。所输入的数据字符长度可以为零。varchar 在 SQL-92 中的同义词为 char varying 或 character varying。
nvarchar(n)
包含 n 个字符的可变长度 Unicode 字符数据。n 的值必须介于 1 与 4,000 之间。字节的存储大小是所输入字符个数的两倍。所输入的数据字符长度可以为零。nvarchar 在 SQL-92 中的同义词为 national char varying 和 national character varying。 n 表示字符个数nvarchar:
不管是一个字符还是一个汉字,都存为2个字节
varchar:
汉字是2个字节,其他字符存为1个字节 通俗一點就是varchar適合輸入英文和數字,nvarchar一般用做中文或其它語言的輸入,這樣到別的語系不會出現亂碼:))2.
N表示Unicode常量,可以解决多语言字符集之间的转换问题,见联机帮助姓名,和房间通常都是用varchar这个数据类型 解释一下:
drop proc a varchar(n):变长型字符数据类型,存储最长长度为8,000 个字符。 举个例子:
create table a (name1 varchar(8))
insert a select '张红a'
--- 存储长度为5个字节,余下的3个字节全部释放
insert a select '王一南'
----存储长度为6个字节,余下的2个字节全部释放
---意思是varchar变长字符数据类型与存储数据的实际长度是一致的 nvarchar(n):可变长度 Unicode 数据,其最大长度为 4,000 字符。
字节的存储大小是所输入字符个数的两倍,
就是说它是双字节来存储数据的。
如果存储数据如果存在单字节时,它也是以双字节来占用存储空间的。 举个例子:
create table aa (name1 nvarchar(8))
insert aa select '张红a'
--- 存储长度为6个字节,余下的2个字节全部释放
--可以防止乱码
declare @s nvarchar(10)
declare @h varchar(10)
set @s=N'帳號' set @h='帳號'
select @s,@h
/*---------- ----------
帳號 ??(1 行受影响)
*/
varchar[(n)]