问个数据库字段nchar和nvarchar的区别
请问什么时候使用nchar,比如说...请问什么时候使用nvarchar,再比如说...还有比如nchar(10)代表10个字符吗?...
请问什么时候使用nchar,比如说...
请问什么时候使用nvarchar,再比如说...
还有比如nchar(10)代表10个字符吗? 展开
请问什么时候使用nvarchar,再比如说...
还有比如nchar(10)代表10个字符吗? 展开
展开全部
NVARCHAR
在存储时,无论是全角还是半角,每个字符都占用两个字节。
在定义时,无论全角或是半角,都是定义字符个数而不是字节数。
最多显示4000个字符(无论全角或半角)
是UNICODE标准字符集。
VARCHAR
在存储时每个半角字符占用1个字节,每个全角字符占用两个字节。
在定义时,如果要存储一个汉字,要定义VARCHAR(2)才可以。要存储一个半角英文字母,VARCHAR(1)即可。
最多显示8000个半角字,4000个全角字
是非UNICODE字符集。
举例说名体会一下吧:
DECLARE @N NVARCHAR(4)
DECLARE @V VARCHAR(4)
SET @N='ABCD'
SET @V='ABCD'
SELECT N=@N,V=@V,NL=len(@n),VL=len(@v)
--结果:ABCD ABCD 4 4
SET @N='工人农民'
set @V='工人农民'
SELECT N=@N,V=@V,NL=len(@n),VL=len(@v)
--结果:工人农民 工人 4 2
===========
我似乎是答错了,看错题了,还以为是NVARCHAR和VARCHAR的区别和用法。白费劲了?
那就再被充一下吧:
NCHAR是定长字符,
NVARCHAR是不定长字符,
如果希望列中所有数据项的大小接近一致,则使用 nchar。
如果希望列中数据项的大小差异很大,则使用 nvarchar。
在存储时,无论是全角还是半角,每个字符都占用两个字节。
在定义时,无论全角或是半角,都是定义字符个数而不是字节数。
最多显示4000个字符(无论全角或半角)
是UNICODE标准字符集。
VARCHAR
在存储时每个半角字符占用1个字节,每个全角字符占用两个字节。
在定义时,如果要存储一个汉字,要定义VARCHAR(2)才可以。要存储一个半角英文字母,VARCHAR(1)即可。
最多显示8000个半角字,4000个全角字
是非UNICODE字符集。
举例说名体会一下吧:
DECLARE @N NVARCHAR(4)
DECLARE @V VARCHAR(4)
SET @N='ABCD'
SET @V='ABCD'
SELECT N=@N,V=@V,NL=len(@n),VL=len(@v)
--结果:ABCD ABCD 4 4
SET @N='工人农民'
set @V='工人农民'
SELECT N=@N,V=@V,NL=len(@n),VL=len(@v)
--结果:工人农民 工人 4 2
===========
我似乎是答错了,看错题了,还以为是NVARCHAR和VARCHAR的区别和用法。白费劲了?
那就再被充一下吧:
NCHAR是定长字符,
NVARCHAR是不定长字符,
如果希望列中所有数据项的大小接近一致,则使用 nchar。
如果希望列中数据项的大小差异很大,则使用 nvarchar。
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询