varchar和Nvarchar区别

来源:互联网 发布:阿里云邮箱删除 编辑:程序博客网 时间:2024/06/05 12:44

转自:http://blog.sina.com.cn/s/blog_44e571d70100cagf.html


Unicode字符集就是为了解决字符集这种不兼容的问题而产生的,它所有的字符都用两个字节表示,即英文字符也是用两个字节表示

 

sql server中的varchar和Nvarchar有什么区别啊,varchar好像是一个英文和一个汉字都站两个字节,而Nvarchar则是一个英文占一个字节,汉字占两个字节。可是这个对asp程序有什么影响?

 
答:
varchar(n)
长度为 n 个字节的可变长度且非 Unicode 的字符数据。n 必须是一个介于 1 和 8,000 之间的数值。存储大小为输入数据的字节的实际长度,而不是 n 个字节。

nvarchar(n)
包含 n 个字符的可变长度 Unicode 字符数据。n 的值必须介于 1 与 4,000 之间。字节的存储大小是所输入字符个数的两倍。

两字段分别有字段值:我和coffee
那么varchar字段占2×2+6=10个字节的存储空间,而nvarchar字段占8×2=16个字节的存储空间。

如字段值只是英文可选择varchar,而字段值存在较多的双字节(中文、韩文等)字符时用nvarchar
 
 
char varchar nvarchar区别
联机帮助上的:
char(n) 定长索引效率高 程序里面使用trim去除多余的空白n 必须是一个介于 1 和 8,000 之间的数值,存储大小为 n 个字节varchar(n)变长效率没char高 灵活n 必须是一个介于 1 和 8,000 之间的数值。存储大小为输入数据的字节的实际长度,而不是 n 个字节text(n)变长非Unicode数据 nchar(n)定长处理unicode数据类型(所有的字符使用两个字节表示)n 的值必须介于 1 与 4,000 之间。存储大小为 n 字节的两倍nvarchar(n)变长处理unicode数据类型(所有的字符使用两个字节表示)n 的值必须介于 1 与 4,000 之间。字节的存储大小是所输入字符个数的两倍。所输入的数据字符长度可以为零ntext(n) 变长处理unicode数据类型(所有的字符使用两个字节表示) 


一般来说,如果含有中文字符,用nchar/nvarchar,如果纯英文和数字,用char/varchar

这里总结的不错
http://www.cnblogs.com/ebaidu/archive/2007/08/14/854778.html
 
 
很多开发者进行数据库设计的时候往往并没有太多的考虑char, varchar类型,有的是根本就没注意,因为存储价格变得越来越便宜了,忘记了最开始的一些基本设计理论和原则,这点让我想到了现在的年轻人,大手一挥一把人民币就从他手里溜走了,其实我想不管是做人也好,做开发也好,细节的把握直接决定很多东西。当然还有一部分人是根本就没弄清楚他们的区别,也就随便选一个。在这里我想对他们做个简单的分析,当然如果有不对的地方希望大家指教。

1、CHAR。CHAR存储定长数据很方便,CHAR字段上的索引效率级高,比如定义char(10),那么不论你存储的数据是否达到了10个字节,都要占去10个字节的空间,不足的自动用空格填充,所以在读取的时候可能要多次用到trim()

2、VARCHAR。存储变长数据,但存储效率没有CHAR高。如果一个字段可能的值是不固定长度的,我们只知道它不可能超过10个字符,把它定义为 VARCHAR(10)是最合算的。VARCHAR类型的实际长度是它的值的实际长度+1。为什么“+1”呢?这一个字节用于保存实际使用了多大的长度。从空间上考虑,用varchar合适;从效率上考虑,用char合适,关键是根据实际情况找到权衡点。

3、TEXT。text存储可变长度的非Unicode数据,最大长度为2^31-1(2,147,483,647)个字符。

4、NCHAR、NVARCHAR、NTEXT。这三种从名字上看比前面三种多了个“N”。它表示存储的是Unicode数据类型的字符。我们知道字符中,英文字符只需要一个字节存储就足够了,但汉字众多,需要两个字节存储,英文与汉字同时存在时容易造成混乱,Unicode字符集就是为了解决字符集这种不兼容的问题而产生的,它所有的字符都用两个字节表示,即英文字符也是用两个字节表示。nchar、nvarchar的长度是在1到4000之间。和char、varchar比较起来,nchar、nvarchar则最多存储4000个字符,不论是英文还是汉字;而char、varchar最多能存储8000个英文,4000个汉字。可以看出使用nchar、nvarchar数据类型时不用担心输入的字符是英文还是汉字,较为方便,但在存储英文时数量上有些损失。

所以一般来说,如果含有中文字符,用nchar/nvarchar,如果纯英文和数字,用char/varchar

我把他们的区别概括成:
CHAR,NCHAR 定长,速度快,占空间大,需处理
VARCHAR,NVARCHAR,TEXT 不定长,空间小,速度慢,无需处理
NCHAR、NVARCHAR、NTEXT处理Unicode码
阅读全文
'); })();
0 0
原创粉丝点击
热门IT博客
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 清道夫吃小鱼 美剧 清道夫 清道夫算鱼吗 清道夫鱼不动 清道夫 足球 清道夫被吃了 清道夫 第一季 清道夫有什么用 清道夫第2季 清道夫不干活 清道夫怎么会死 清道夫怎么繁殖 清道夫鱼寿命 豹纹清道夫鱼 清道夫有几种 清道夫演员表 什么叫清道夫 清道夫变白了 鹦鹉吃清道夫 罗汉鱼 清道夫 清道夫好看吗 清道夫为什么不能吃 清道夫鱼的营养价值 清道夫鱼为什么会死 清道夫吃鱼的粪便吗 血管清道夫的保健品 血管清道夫的食物有哪些 除了清道夫还有什么鱼 鹦鹉鱼把清道夫吃了 求生之路清道夫模式 青道夫 瓷器酒罐 玻璃酒罐 陶瓷酒罐 郎陵罐酒价格 二手不锈钢酒罐 不锈钢酒罐生产厂家 咸鱼魔尊在线掉马 清陶浅醉 一梦醉兰池 蚩尤经 醉梦梦醒 清醒梦的危害