zoukankan      html  css  js  c++  java
  • 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的。

         (五)题外话

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

            

  • 相关阅读:
    iframe显示高度自适应 兼容多浏览器
    Asp.Net在Global.asax中实现URL 的重写
    文件流下载 ASP.NET
    Asp.Net实现全局定时器功能
    C#中获取本机IP地址,子网掩码,网关地址
    Asp.Net缓存实例
    Google API 天气数据缓存到一个XML中
    获取服务器信息
    C# NET 中英混合字符串截断实例
    Asp.Net实现长文章分页显示功能
  • 原文地址:https://www.cnblogs.com/gdouzz/p/7094522.html
Copyright © 2011-2022 走看看