nvarchar与varchar的区别

一直以来对varchar和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个字节全部释放  

     谢谢二位了啊!
 

转载于:https://www.cnblogs.com/wwd252/archive/2008/05/13/1195371.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值