当前位置:网站首页 > 技术博客 > 正文

varchar跟nvarchar



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

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

 

CREATE TABLE Test ( vStr varchar(10), nStr nvarchar(10) ) --对于数字 INSERT INTO [dbo].[Test] VALUES('','') --对于字母 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的。

转载自:https://www.cnblogs.com/gdouzz/p/7094522.html

  • 上一篇: time has value
  • 下一篇: 时序卷积网络
  • 版权声明


    相关文章:

  • time has value2025-05-21 11:30:06
  • java中方法是啥2025-05-21 11:30:06
  • springboot上传文件到项目中2025-05-21 11:30:06
  • java 单元测试工具2025-05-21 11:30:06
  • 面试被问到怎么做接口测试2025-05-21 11:30:06
  • 时序卷积网络2025-05-21 11:30:06
  • archlinux双系统分区2025-05-21 11:30:06
  • 微信小程序码生成2025-05-21 11:30:06
  • ubuntu vnc开机自启动2025-05-21 11:30:06
  • 深度优先遍历算法代码2025-05-21 11:30:06