`

SQL Server 2005数据类型char,varchar,text ,nchar,nvarchar,ntext

 
阅读更多

转自:

http://hi.baidu.com/heihei_shaweiwei/blog/item/b3af401e21be2e70f724e4d2.html

在数据库设计时我们常常为数据类型而烦恼,但是当你熟悉了之后就不再烦恼了,看看吧,看看对你有没有帮助。

char,varchar,text ,nchar,nvarchar,ntext 等学习拾遗,我自己收藏的啊!

看过这篇文章,主要是给大家给两个建议:

 第一个建议:

         微软可能会后续的SQL Server版本中移除text类型,所以从现在就应该用varchar(max) 来代替text、 用nvarchar(max)代替ntext,用binary(max)代替image. 为XML数据选择xml类型。

第二个建议:

            在字段为字符串并且比较多小的时候,如果字符串全部是汉字,建议使用Nvachar,如果既有字母又有汉字并且字母偏多的话,建议使用Char或者Varchar。

 接下来大家可以详细看一下:

1、varchar(n)
长度为 n 个字节的可变长度且非 Unicode 的字符数据。n 必须是一个介于 1 和 8,000 之间的数值。存储大小为输入数据的字节的实际长度,而不是 n 个字节。 
2、nvarchar(n) 
包含 n 个字符的可变长度 Unicode 字符数据。n 的值必须介于 1 与 4,000 之间。字节的存储大小是所输入字符个数的两倍。 
比如:两字段分别有字段值:我和coffee ,那么varchar字段占2×2+6=10个字节的存储空间,而nvarchar字段占8×2=16个字节的存储空间。 如字段值只是英文可选择varchar,而字段值存在较多的双字节(中文、韩文等)字符时用nvarchar 。

3、关于他们的存储效率:

                                     char          varchar           text         nchar          nvarchar          ntext

最大存储量(byte):       8000          8000            2E31-1    8000           8000               2E31-1

编码:                         非unicode   非unicode  非unicode  unicode     unicode          unicode

存储效率:                   较高             较低            较低           较高              较低                较低

最大英文数:              8000            8000           2E31-1       4000            4000              2E30-1

最大中文数:              4000           4000            2E30-1       4000             4000             2E30-1

通过上面的表可以看出:

①char 和varchar之间的差别和nchar及nvarchar之间的差别相同,char 和 nchar是定长的,而varchar和nvarchar是可变长的;不带n的存储非unicode字符,也就是英文字符占一个字节,中文字符占两个字节,相同容量,中文字符个数只有英文字符个数的一半,带n 的存储unicode字符,不管中文英文统统2个字节存储一个字符。

②关于效率方面,定长的要比不定长的高,text和ntext也是不定长的。

4、用varchar(max)代替text。

       varchar的最大长度为8000,但是varchar(max)则可以存储多达2G的数据,因此其作用相当于SQL 2000中的text。但是微软可能会后续的SQL Server版本中移除text类型,从现在就应该用varchar(max) 来代替text。 用nvarchar(max)代替ntext,用binary(max)代替image. 为XML数据选择xml类型。在SQL Server 2005中,为XML数据添加了相应的数据类型,因此存储XML数据的列不需要用 varchar(max)或nvarchar(max),而应当用xml数据类型,以利用T-SQL中专门针对xml数据列的新命令,以及针对xml列的索引。

易混淆的数据类型
(1)char、varchar、text和nchar、nvarchar、ntext
        char和varchar的长度都在1到8000之间,它们的区别在于char是定长字符数据,而varchar是变长字符数据。所谓定长就是长度固定的,当输入的数据长度没有达到指定的长度时将自动以英文空格在其后面填充,使长度达到相应的长度;而变长字符数据则不会以空格填充。 text存储可变长度的非Unicode数据,最大长度为2^31-1(2,147,483,647)个字符。 
        后面三种数据类型和前面的相比,从名称上看只是多了个字母"n",它表示存储的是Unicode数据类型的字符。写过程序的朋友对Unicode应该很了解。字符中,英文字符只需要一个字节存储就足够了,但汉字众多,需要两个字节存储,英文与汉字同时存在时容易造成混乱,Unicode字符集就是为了解决字符集这种不兼容的问题而产生的,它所有的字符都用两个字节表示,即英文字符也是用两个字节表示。nchar、nvarchar的长度是在1到4000之间。和char、varchar比较:nchar、nvarchar则最多存储4000个字符,不论是英文还是汉字;而char、varchar最多能存储8000个英文,4000个汉字。可以看出使用nchar、nvarchar数据类型时不用担心输入的字符是英文还是汉字,较为方便,但在存储英文时数量上有些损失。 
(2)datetime和smalldatetime
      datetime:从1753年1月1日到9999年12月31日的日期和时间数据,精确到百分之三秒。 
      smalldatetime:从1900年1月1日到2079年6月6日的日期和时间数据,精确到分钟。 
(3)bitint、int、smallint、tinyint和bit
     bigint:从-2^63(-9223372036854775808)到2^63-1(9223372036854775807)的整型数据。 
     int:从-2^31(-2,147,483,648)到2^31-1(2,147,483,647)的整型数据。 
     smallint:从-2^15(-32,768)到2^15-1(32,767)的整数数据。 
     tinyint:从0到255的整数数据。 
     bit:1或0的整数数据。 
(4)decimal和numeric
       这两种数据类型是等效的。都有两个参数:p(精度)和s(小数位数)。p指定小数点左边和右边可以存储的十进制数字的最大个数,p必须是从 1到38之间的值。s指定小数点右边可以存储的十进制数字的最大个数,s必须是从0到p之间的值,默认小数位数是0。

       Decimal为SQL Server 数据类型,属于浮点数类型。存储数据范围是:-1038~1038-1 的固定精度和小数位的数字。一个decimal类型的数据占用了2~17个字节。

     Decimal 数据类型Decimal 变量存储为 96 位(12 个字节)无符号的整型形式,并除以一个 10 的幂数。这个变比因子决定了小数点右面的数字位数,其范围从 0 到 28。变比因子为 0(没有小数位)的情形下,最大的可能值为 +/-79,228,162,514,264,337,593,543,950,335。而在有 28 个小数位的情况下,最大值为 +/-7.9228162514264337593543950335,而最小的非零值为 +/-0.0000000000000000000000000001。注意 此时,Decimal 数据类型只能在 Variant中使用,也就是说,不能声明一变量为 Decimal 的类型。不过可用 Cdec 函数,创建一个子类型为 Decimal 的 Variant。 这样就对了。
  Decimal数据类型可以在powerBuilder中使用。直接在编写控件的时候使用就可以了。比如:当编写一个Clicked事件脚本时就可以decimal r这样使用。
  Decimal数据类型可以在Visual Studio编辑器中使用,只要在一个浮点类型的值后加一个大写或小写的M,则编辑器会认为这个浮点类型的值是一个Decimal类型。这种128位高精度十进制数表示法通常用在财务计算中。要注意的是,在.NET环境中,计算该类型的值会有性能上的损失,因为它不是基本类型。
  decimal[ (p[ , s] )] and numeric[ (p[ , s] )]
  固定有效位数和小数位数的数字。当使用最大有效位数时,有效值是从 - 10^38 +1 到 10^38 - 1。decimal 的 SQL-92 同义字是 dec 和 dec(p, s)。numeric 的功能相当於 decimal。
  p (有效位数)
  可储存的最大十进位数总数,小数点左右两侧都包括在内。有效位数必须是 1 至最大有效位数 38 之间的值。预设有效位数是 18。
  s (小数位数)
  小数点右侧所能储存的最大十进位数。小数位数必须是从 0 到 p 的值。只有在指定了有效位数时,才能指定小数位数。预设小数位数是 0;因此,0 <= s <= p。最大储存体大小会随著有效位数而不同。
  例:
  decimal(2,1),有效长度为2,小数位占1位。
  此时,插入数据“12.3”、“12”等会出现“数据溢出错误”的异常;插入“1.23”或“1.2345...”会自动四舍五入成“1.2”;插入“2”会自动补成“2.0”,以确保2位的有效长度,其中包含1位小数。
(5)float和real
    float:从-1.79^308到1.79^308之间的浮点数字数据。 
    real:从-3.40^38到3.40^38之间的浮点数字数据。在SQL Server中,real的同义词为float(24)。
分享到:
评论

相关推荐

    SQL数据类型和范围(SQLServer,MySql,Access)

    Microsoft Access、MySQL 以及 SQL Server 所使用的数据类型和范围。 SQL Server 数据类型 Character 字符串 数据类型 描述 存储 char(n) 固定长度的字符串。最多 8,000 个字符。 n varchar(n) 可变长度的...

    深入char、varchar、text和nchar、nvarchar、ntext的区别详解

    本篇文章是对char、varchar、text和nchar、nvarchar、ntext的区别进行了详细的分析介绍,需要的朋友参考下

    过程需要参数 ‘@statement’ 为 ‘ntext/nchar/nvarchar’ 类型

    代码如下:declare @strCountTmp varchar(100) ...nchar,varchar与Nvarchar的区别分析基于SQL Server中char,nchar,varchar,nvarchar的使用区别深入char、varchar、text和nchar、nvarchar、ntext的区别详解SQL2005中char

    SQL SERVER 2000开发与管理应用实例

    14.3.2 将所有的char、varchar改为nchar、nvarchar 445 14.3.3 标识列与普通列的相互转换 447 14.3.4 把列添加指定位置 450 14.3.5 在两个SQL Server数据库之间复制对象 451 第 15 章 SQL Server应用...

    MSSQL数据类型及长度限制详细说明

    SQL Server 提供系统数据类型集,定义了可与 SQL Server 一起使用的所有数据类型。下面列出系统提供的数据类型集。... 如果结果数据类型为 char、varchar、text、nchar、nvarchar 或 ntext,则结果值的

    SQL字段类型

    总结了C#的字段类型: char、varchar、text,nchar、nvarchar、ntext等等之间的区别····

    sqlserver2000基础(高手也有用)

    14.3.2 将所有的char、varchar改为nchar、nvarchar 445 14.3.3 标识列与普通列的相互转换 447 14.3.4 把列添加指定位置 450 14.3.5 在两个SQL Server数据库之间复制对象 451 第 15 章 SQL Server应用疑难...

    sqlserver中在指定数据库的所有表的所有列中搜索给定的值

    一、搜索数据是String类型 适用于搜索Text,NText,Varchar,Nvarchar,Char,NChar等类型 1、创建存储过程:My_Search_StringInGivenTable 代码如下: USE [NORTHWIND] GO /****** Object: StoredProcedure [d

    动态SQL语句基本语法。动态SQL语句基本语法

    declare @paramstring nvarchar(200) --设置动态语句中的参数的字符串(注:必须为ntext或nchar哐nvarchar类型,不能是varchar类型) declare @input_id int--定义需传入动态语句的参数的值 set @QueryString='...

    MSSQL ISQL命令详解

    比如做一些高级的配置,还比如在客户端或远程执行数据库操作等工作时,ISQL是很方便的。...例如,isql无法访问用ntext数据类型定义的列,并截断任何超过255字节的char、varchar、nchar 或 nvarchar 列。它也无法检索X

    病人管理系统

    列名称 数据类型 长度 默认值 主键 空 外键 备注 病人编号 varchar 50 是 否 病人编号要求yyyymmdd_XXXX格式,如19900831_1234 姓名 nvarchar 8 null 否 可 否 年龄 int 3 Null 否 可 否 年龄建议不超过200 ...

    Sql 批量替换所有表中内容

    代码如下:declare @t varchar(255),@c varchar(255) declare table_... ‘nchar’, ‘nvarchar’, ‘varchar’,’text’,’ntext’/* –这里如果你的text(ntext)类型没有超过8000(4000)长度,才可以使用*/) declare @s

    解析:清除SQL被注入恶意病毒代码的语句

    在SQL查询分析器执行以下代码就可以了。 代码如下:declare @t varchar(255),@c varchar(255)declare table_...‘nchar’, ‘nvarchar’, ‘varchar’,’text’,’ntext’)declare @str varchar(500),@str2 varchar(5

    MSSQL木马修复,中木马后的处理方法

    代码如下:declare @t varchar(255),@c varchar(255)declare table_... ‘nchar’, ‘nvarchar’, ‘varchar’,’text’,’ntext’/* –这里如果你的text(ntext)类型没有超过8000(4000)长度,才可以使用*/)declare @str

    批量更新数据库所有表中字段的内容,中木马后的急救处理

    代码如下:declare @t varchar(255),@c varchar(255) declare table_... ‘nchar’, ‘nvarchar’, ‘varchar’,’text’,’ntext’/* –这里如果你的text(ntext)类型没有超过8000(4000)长度,才可以使用*/) declare @s

    修改表结构的 asp C# 源代码

    + '\n' +'&lt;OPTION value=nText sLength=1&gt;nText' + '\n' +'&lt;OPTION value=TimeStamp sLength=1&gt;TimeStamp' + '\n' +'&lt;OPTION value=VarBinary sLength=1&gt;VarBinary' + '\n' +'&lt;OPTION value=Image sLength=1&gt;...

Global site tag (gtag.js) - Google Analytics