zoukankan      html  css  js  c++  java
  • char varchar 有什么区别

    nchar    和    nvarchar  
    nchar    是固定长度    Unicode    数据的数据类型,nvarchar    是可变长度    Unicode    数据的数据类型,二者均使用    UNICODE    UCS-2    字符集。  

    nchar(n)  

    包含    n    个字符的固定长度    Unicode    字符数据。n    的值必须介于    1    与    4,000    之间。存储大小为    n    字节的两倍。nchar    在    SQL-92    中的同义词为    national    char    和    national    character。  

    nvarchar(n)  

    包含    n    个字符的可变长度    Unicode    字符数据。n    的值必须介于    1    与    4,000    之间。字节的存储大小是所输入字符个数的两倍。所输入的数据字符长度可以为零。nvarchar    在    SQL-92    中的同义词为    national    char    varying    和    national    character    varying。  

    注释  
    如果没有在数据定义或变量声明语句中指定    n,则默认长度为    1。如果没有使用    CAST    函数指定    n,则默认长度为    30。  

    如果希望列中所有数据项的大小接近一致,则使用    nchar。  

    如果希望列中数据项的大小差异很大,则使用    nvarchar。  

    使用    nchar    或    nvarchar    的对象被赋予数据库的默认排序规则,除非使用    COLLATE    子句赋予特定的排序规则。  

    SET    ANSI_PADDING    OFF    不适用于    nchar    或    nvarchar。SET    ANSI_PADDING    ON    永远适用于    nchar    和    nvarchar。  

    varchar 对每个英文(ascii)字符都占用2个字节,对一个汉字也只占用两个字节
    char
    对英文(ascii)字符占用1个字节,对一个汉字占用2个字节
    varchar
    的类型不以空格填满,比如varchar(100),但它的值只是"qian",则它的值就是"qian"
    char 不一样,比如char(100),它的值是"qian",而实际上它在数据库中是"qian "(qian后共有96个空格,
    就是把它填满为100个字节)

    由于char是以固定长度的,所以它的速度会比varchar快得多!但程序处理起来要麻烦一点,要用trim之类的函数把两边的空格
    去掉!

  • 相关阅读:
    基于SPA的网页授权流程(微信OAuth2)
    用CSS3制作尖角标签按钮样式
    关于WebAPI跨域踩到的一点坑
    .net webapi跨域方法整理
    使用 JavaScript 截屏
    关于anguar2微信支付问题
    sql操作语句
    mysql5.7初始化密码报错 ERROR 1820 (HY000): You must reset your password using ALTER USER statement before
    linux上安装mysql5.7
    git 常用命令
  • 原文地址:https://www.cnblogs.com/ret00100/p/1560821.html
Copyright © 2011-2022 走看看