zoukankan      html  css  js  c++  java
  • 学习之路三十一:Varchar和NVarchar的理解

    前段时间在测试的时候发现了一个问题,看过Log之后发现在插入数据到数据库的时候发生异常了!

    原因是由于插入的字符串太长,项目中的用到的类型是NVARCHAR,下面就是对它们的理解:

    1.VARCHAR -- 字节数

      示例:VARCHAR(10) - [中文代表两个字节数]

      上面的定义表示我存储的字节数为10个,那么英文就能存10个,中文只能存5个!

    2.NVARCHAR -- 字符数

      示例:NVARCHAR(10) - [中文代表两个字节]

      上面的定义为我存储的字符数为10个,那么英文就能存10个,那么中文也能存10个!

        如果把NVARCHAR理解为存储的是字符数,那么就很容易理解在存储中文时的规则了.

    3.总结:

    英文

    中文

    VARCHAR(n)

    字节数

    N

    n/2

    NVARCHAR(n)

    字符数

    N

    n

     

     

     

     

     

      2013-11-30的补充:

             ► 从存储方式上,nvarchar是按字符存储的,而 varchar是按字节存储的;

             ► 从存储量上考虑, varchar比较节省空间,因为存储大小为字节的实际长度,而 nvarchar是双字节存储;

             ► 在使用上,如果存储内容都是英文字符而没有汉字等其他语言符号,建议使用varchar;含有汉字的使用nvarchar,因为nvarchar是使用Unicode编码,即统一的字符编码标准,会减少乱码的出现几率;

            ►如果你做的项目可能涉及不同语言之间的转换,建议用nvarchar。

      这点要注意:varchar   适合与存储英文和数字;   nvarchr一般用于存储中文或其他语言的输入,因为   这样,可以防止到其他语言平台上出现乱码的问题。

      

      关于它们更深入的理解可以看下面的参考文章.

     

    参考文章:

    1.varchar和Nvarchar区别

    2.char、varchar、text和nchar、nvarchar、ntext的区别

     

    以同步至:个人文章目录索引

      

  • 相关阅读:
    RedisTemplate使用事务处理
    maven命令学习
    springboot学习地址
    Mycat实现读写分离
    springboot-异步线程调用
    java多线程ExecutorService
    IntelliJ Idea 常用快捷键列表
    springMVC请求处理过程
    记录一次面试题
    java面试题-java内存模型
  • 原文地址:https://www.cnblogs.com/yangcaogui/p/3113524.html
Copyright © 2011-2022 走看看