• nvarchar与varchar的区别


     

    1.
    varchar[(n)]   
         长度为n个字节的可变长度且非Unicode的字符数据。n 必须是一个介于1和8,000之间的数值。存储大小为输入数据的字节的实际长度,而不是n个字节。所输入的数据字符长度可以为零。varchar在SQL-92中的同义词为 char  varying      或  character  varying。   
        

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

    n 表示字符个数

    nvarchar:   
         不管是一个字符还是一个汉字,都存为2个字节   
         varchar:   
         汉字是2个字节,其他字符存为1个字节   

    通俗一點就是varchar適合輸入英文和數字,nvarchar一般用做中文或其它語言的輸入,這樣到別的語系不會出現亂碼:))

    2.
    N表示Unicode常量,可以解决多语言字符集之间的转换问题,见联机帮助

    姓名,和房间通常都是用varchar这个数据类型  
       
      解释一下:  
      drop   proc   a  
       
      varchar(n):变长型字符数据类型,存储最长长度为8,000   个字符。  
       
      举个例子:  
      create   table   a   (name1   varchar(8))  
      insert   a   select   '张红a'      
              ---   存储长度为5个字节,余下的3个字节全部释放  
      insert   a   select   '王一南'  
              ----存储长度为6个字节,余下的2个字节全部释放  
      ---意思是varchar变长字符数据类型与存储数据的实际长度是一致的  
       
      nvarchar(n):可变长度   Unicode   数据,其最大长度为   4,000   字符。  
        字节的存储大小是所输入字符个数的两倍,  
      就是说它是双字节来存储数据的。  
      如果存储数据如果存在单字节时,它也是以双字节来占用存储空间的。  
       
      举个例子:  
      create   table   aa   (name1   nvarchar(8))  
      insert   aa   select   '张红a'      
              ---   存储长度为6个字节,余下的2个字节全部释放  

  • 相关阅读:
    SDSF output to PS
    3亿人出走后的中国农村,路在何方?
    oracle function
    C8051特点
    c8051单片机注意事项:
    一个因xdata声明引起的隐含错误
    宏 函数 内联函数inline
    字符串与液晶显示的一个问题
    XON/OFF
    excel之实验数据处理线性拟合
  • 原文地址:https://www.cnblogs.com/liuhaitao/p/1401493.html
Copyright © 2020-2023  润新知