nvarchar 和varchar区别

       有时候设计字段的时候,碰到nvarchar和varchar时候,是有点犹豫。所以今天就来探个究竟把。

     (一)  varchar是非Unicode可变长度类型,nvarchar是Unicode编码可变长度类型

DECLARE @name AS VARCHAR(50)='我是中国人test'
SELECT @name AS Name,
DATALENGTH(@name) AS [Length]

 

DECLARE @nname AS NVARCHAR(50)='我是中国人test'
SELECT @nname AS Name,
DATALENGTH(@nname) AS [Length]

    (二)它们两者的最大长度不一样

        nvarchar的最大值是4000

       varchar最大值是8000

       (三) varchar能存储的字节数就是它的长度,nvarchar能存储的字节数是它的长度乘2

CREATE TABLE Test
(
  vStr varchar(10),
  nStr nvarchar(10)
)

--对于数字
INSERT INTO [dbo].[Test] VALUES('1234567890','1234567890')

--对于字母
INSERT INTO [dbo].[Test] VALUES('abcdefghik','abcdefghik')

--对于汉字
INSERT INTO [dbo].[Test] VALUES('我是中国人','我是中国人我爱我祖国')

--对于汉字和字母
INSERT INTO [dbo].[Test] VALUES('我是中国zz','我是中国人zhang')

 

     (四) 实际开发中,如何选择,到底是用哪个好呢?

        总的来说,我是比较推崇使用nvarchar

         有人说,varchar比nvarchar更省空间,应该更多的用varchar。但是我不是很赞同这个观点,首先,现在空间相对来说已经不是那么缺少了,没有必要太纠结于空间这个了,还有一点就是现在的操作系统基本上内部解析基本上都是用Unicode编码的,使用了nvarchar你可以避免每次从数据库读取或写入时候,进行编码转换,转换需要时间,并且很容易出错。如果出错,恢复回来可没那么简单,并且nvarchar是支持多种语言的。所以我大部分时间做数据库设计的时候都是用nvarchar的。

     (五)题外话

        各位园友,有啥看法的,能否告知一下,谢谢

        

posted @ 2017-06-29 15:06  GDOUJKZZ  阅读(72409)  评论(5编辑  收藏  举报