【转贴】SQL Server中char/varchar/nchar/nvarchar的区别

文章来源:http://www.leadtrade123.cn/2009/04/12/847.html

作者:匿名

 

      当我们建立数据库表时,都会根据字段特点选择适当的数据类型,这次主要讲的是关于字符类型,在我们平时的数据库结构当中,字符类型占绝大多数,如何高效准备地利用数据库和优化数据库结构是每个DBA必须掌握的技能。

      在SQL Server中,现在主要以SQL Server2005为例。对于字符类型的有:

      char:固定长度,存储ANSI字符,不足的补英文半角空格。

      nchar:固定长度,存储Unicode字符,不足的补英文半角空格

      varchar:可变长度,存储ANSI字符,根据数据长度自动变化。

      nvarchar:可变长度,存储Unicode字符,根据数据长度自动变化。

      如果你肯定存储的数据长度,而且不包中文的,可以选择char类型。

      如果肯定存储的数据长度,但可能包括中文,可以选择nchar类型。

      如果不确定存储的数据长度,也有可能有中文,可以选择nvarchar类型,在SQL Server2005中也是比较常用的字符数据类型。

      ANSI主要是以单字节来存储数据,一般适合英文。而我们常用的汉字需要用两个字节来存储,所以就要使用unicode的数据类型,不然读取出来的数据可能会乱码。

      一个字符数据类型最大8000,如果使用了Unicode来存储就变成只能存储4000个字符。

      如果存储的是文章内容等超长文本数据的,可以使用nText类型,也是可变长度的。总是前面凡带n开头的表示以unicode来存储数据,以var前缀的表示可变长。

      如果高效利用,就看自己的具体需要,有时为了以后数据结构的变动,常使用nvarchar的比较多。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值