sqlserver字段类型详解
bit    整型
bit数据类型是整型,其值只能是0、1或空值。这种数据类型⽤于存储只有两种可能值的数据,如Yes 或No、True 或False 、On 或Off.
注意:很省空间的⼀种数据类型,如果能够满⾜需求应该尽量多⽤。
tinyint  整型
tinyint 数据类型能存储从0到255 之间的整数。它在你只打算存储有限数⽬的数值时很有⽤。这种数据类型在数据库中占⽤1 个字节.
注意:如果bit类型太单调不能满⾜您的需求,您可以考虑⽤tinyint类型,因为这个类型相对也是⽐较安全的,不接受恶意脚本内容的嵌⼊。
smallint    整型
smallint 数据类型可以存储从- 2的15次幂(-32768)到2的15次幂(32767)之间的整数。这种数据类型对存储⼀些常限定在特定范围内的数值型数据⾮常有⽤。这种数据类型在数据库⾥占⽤2 字节空间.
注意:如果tinyint类型太单调不能满⾜您的需求,您可以考虑⽤smallint类型,因为这个类型相对也是⽐较安全的,不接受恶意脚本内容的嵌⼊。
int    整型
int 数据类型可以存储从- 2的31次幂(-2147483648)到2的31次幂 (2147483 647)之间的整数。存储到数据库的⼏乎所有数值型的数据都可以⽤这种数据类型。这种数据类型在数据库⾥占⽤4个字节.
注意:如果smallint也不能够满⾜您的需求,您可以考虑⽤长度更⼤的int类型。
decimal  精确数值型
decimal 数据类型能⽤来存储从-10的38次幂-1到10的38次幂-1的固定精度和范围的数值型数据。使⽤这种数据类型时,必须指定范围和精度。范围是⼩数点左右所能存储的数字的总位数。精度是⼩数点右边存储的数字的位数
numeric  精确数值型
numeric数据类型与decimal 相似。
smallmoney    货币型
smallmoney 数据类型⽤来表⽰钱和货币值。这种数据类型能存储从-214748.3648 到214748.3647 之间的数据,精确到货币单位的万分之⼀
money  货币型
money数据类型⽤来表⽰钱和货币值。这种数据类型能存储从-9220亿到9220 亿之间的数据,精确到货币单位的万分之⼀
float    近似数值型
float 数据类型是⼀种近似数值类型,供浮点数使⽤。说浮点数是近似的,是因为在其范围内不是所有的数都能精确表⽰。浮点数可以是从-1.79E+308到1.79E+308 之间的任意数
real    近似数值型
real 数据类型像浮点数⼀样,是近似数值类型。它可以表⽰数值在-3.40E+38到3.40E+38之间的浮点数
Smalldatetime  ⽇期时间型
smalldatetime 数据类型⽤来表⽰从1900年1⽉1⽇到2079年6⽉6⽇间的⽇期和时间,精确到⼀分钟
datetime  ⽇期时间型
datetime数据类型⽤来表⽰⽇期和时间。这种数据类型存储从1753年1⽉1⽇到9999年12⽉31⽇间所有的⽇期和时间数据,精确到三百分之⼀秒或3.33毫秒 .
cursor    特殊数据型
cursor 数据类型是⼀种特殊的数据类型,它包含⼀个对游标的引⽤。这种数据类型⽤在存储过程中,⽽且创建表时不能⽤
timestamp  特殊数据型
timestamp 数据类型是⼀种特殊的数据类型,⽤来创建⼀个数据库范围内的唯⼀数码。⼀个表中只能有⼀个timestamp列。每次插⼊或修改⼀⾏
时,timestamp列的值都会改变。尽管它的名字中有“time”,但timestamp列不是⼈们可识别的⽇期。在⼀个数据库⾥,timestamp值是唯⼀的Uniqueidentifier    特殊数据型
Uniqueidentifier数据类型⽤来存储⼀个全局唯⼀标识符,即GUID。GUID确实是全局唯⼀的。这个数⼏乎没有机会在另⼀个系统中被重建。可以使⽤NEWID 函数或转换⼀个字符串为唯⼀
标识符来初始化具有唯⼀标识符的列 .
char    字符型
char数据类型⽤来存储指定长度的定长⾮统⼀编码型的数据。当定义⼀列为此类型时,你必须指定列长。当你总能知道要存储的数据的长度时,此数据类型很有⽤。例如,当你按加4个字符格式来存储数据时,你知道总要⽤到10个字符。此数据类型的列宽最⼤为8000 个字符.
varchar  字符型              varchar数据类型,同char类型⼀样,⽤来存储⾮统⼀编码型字符数据。与char 型不⼀样,此数据类型为变长。当定义⼀列为该数据类型时,你要指定该列的最⼤长度。它与char数据类型最⼤的区别是,存储的长度不是列长,⽽是数据的长度  .
text    字符型
text 数据类型⽤来存储⼤量的⾮统⼀编码型字符数据。这种数据类型最多可以有231-1或20亿个字符.
nchar    统⼀编码字符型
nchar 数据类型⽤来存储定长统⼀编码字符型数据。统⼀编码⽤双字节结构来存储每个字符,⽽不是⽤单字节(普通⽂本中的情况)。它允许⼤量的扩
展字符。此数据类型能存储4000种字符,使⽤的字节空间上增加了⼀倍.
nvarchar    统⼀编码字符型
nvarchar 数据类型⽤作变长的统⼀编码字符型数据。此数据类型能存储4000种字符,使⽤的字节空间增加了⼀倍.
ntext    统⼀编码字符型
ntext 数据类型⽤来存储⼤量的统⼀编码字符型数据。这种数据类型能存储230 -1或将近10亿个字符,且使⽤的字节空间增加了⼀倍
binary    ⼆进制数据类型
binary数据类型⽤来存储可达8000 字节长的定长的⼆进制数据。当输⼊表的内容接近相同的长度时,你应该使⽤这种数据类型.
varbinary    ⼆进制数据类型
varbinary 数据类型⽤来存储可达8000 字节长的变长的⼆进制数据。当输⼊表的内容⼤⼩可变时,你应该使⽤这种数据类型
image    ⼆进制数据类型
image 数据类型⽤来存储变长的⼆进制数据,最⼤可达231-1或⼤约20亿字节
---------------------------------------------------
(1)⼆进制数据类型
  ⼆进制数据包括 Binary、Varbinary 和 Image
  Binary 数据类型既可以是固定长度的(Binary),也可以是变长度的。
  Binary[(n)] 是 n 位固定的⼆进制数据。其中,n 的取值范围是从 1 到 8000。其存储窨的⼤⼩是 n + 4 个字节。
  Varbinary[(n)] 是 n 位变长度的⼆进制数据。其中,n 的取值范围是从 1 到 8000。其存储窨的⼤⼩是 n + 4个字节,不是n 个字节。
  在 Image 数据类型中存储的数据是以位字符串存储的,不是由 SQL Server 解释的,必须由应⽤程序来解释。例如,应⽤程序可以使⽤BMP、TIEF、GIF 和 JPEG 格式把数据存储在 Image 数据类型中。
(2)字符数据类型
  字符数据的类型包括 Char,Varchar 和 Text
  字符数据是由任何字母、符号和数字任意组合⽽成的数据。
  Varchar 是变长字符数据,其长度不超过 8KB。Char 是定长字符数据,其长度最多为 8KB。超过 8KB 的ASCII 数据可以使⽤Text数据类型存储。例如,因为 Html ⽂档全部都是 ASCII 字符,并且在⼀般情况下长度超过 8KB,所以这些⽂档可以 Text 数据类型存储在SQL Server 中。
(3)Unicode 数据类型
  Unicode 数据类型包括 Nchar,Nvarchar 和Ntext
  在 Microsoft SQL Server 中,传统的⾮ Unicode 数据类型允许使⽤由特定字符集定义的字符。在 SQL Server安装过程中,允许选择⼀种字符集。使⽤ Unicode 数据类型,列中可以存储任何由Unicode 标准定义的字符。在 Unicode 标准中,包括了以各种字符集定义的全部字符。使⽤Unicode数据类型,所战胜的窨是使⽤⾮ Unicode 数据类型所占⽤的窨⼤⼩的两倍。
  在 SQL Server 中,Unicode 数据以 Nchar、Nvarchar 和 Ntext 数据类型存储。使⽤这种字符类型存储
的列可以存储多个字符集中的字符。当列的长度变化时,应该使⽤Nvarchar 字符类型,这时最多可以存储 4000 个字符。当列的长度固定不变时,应该使⽤ Nchar 字符类型,同样,这时最多可以存储4000 个字符。当使⽤ Ntext 数据类型时,该列可以存储多于 4000 个字符。
(4)⽇期和时间数据类型
  ⽇期和时间数据类型包括 Datetime 和 Smalldatetime两种类型
  ⽇期和时间数据类型由有效的⽇期和时间组成。例如,有效的⽇期和时间数据包括“4/01/98 12:15:00:00:00 PM”和“1:28:29:15:01AM 8/17/98”。前⼀个数据类型是⽇期在前,时间在后⼀个数据类型是霎时间在前,⽇期在后。在 Microsoft SQL Server中,⽇期和时间数据类型包括Datetime 和Smalldatetime 两种类型时,所存储的⽇期范围是从 1753 年 1 ⽉ 1 ⽇开始,到9999 年12 ⽉ 31 ⽇结束(每⼀个值要求 8 个存储字节)。使⽤Smalldatetime 数据类型时,所存储的⽇期范围是 1900年 1 ⽉ 1⽇开始,到 2079 年 12 ⽉ 31 ⽇结束(每⼀个值要求 4 个存储字节)。
  ⽇期的格式可以设定。设置⽇期格式的命令如下:
  Set DateFormat {format | @format _var|
  其中,format | @format_var 是⽇期的顺序。有效的参数包括 MDY、DMY、YMD、YDM、MYD 和 D
YM。在默认情况下,⽇期格式为MDY。  例如,当执⾏ Set DateFormat YMD 之后,⽇期的格式为年⽉⽇形式;当执⾏ Set DateFormat DMY 之后,⽇期的格式为⽇⽉有年形式
(5)数字数据类型
  数字数据只包含数字。数字数据类型包括正数和负数、⼩数(浮点数)和整数
  整数由正整数和负整数组成,例如 39、25、0-2 和 33967。在 Micrsoft SQL Server 中,整数存储的数据类型是  Int,Smallint和 Tinyint。Int 数据类型存储数据的范围⼤于 Smallint 数据类型存储数据的范围,⽽ Smallint 据类型存储数据的范围⼤于Tinyint 数据类型存储数据的范围。使⽤ Int 数据狗昔存储数据的范围是从 -2 147 483 648 到 2 147 483 647(每⼀个值要求4个字节存储空间)。使⽤ Smallint 数据类型时,存储数据的范围从 -32 768 到 32 767(每⼀个值要求2个字节存储空间)。使⽤Tinyint 数据类型时,存储数据的范围是从0 到255(每⼀个值要求1个字节存储空间)。  精确⼩娄数据在 SQL Server 中的数据类型是 Decimal 和 Numeric。这种数据所占的存储空间根据该数据的位数后的位数来确定。
  在SQL Server 中,近似⼩数数据的数据类型是 Float 和 Real。例如,三分之⼀这个分数记作。3333333,当使⽤近似数据类型时能准确表⽰。因此,从系统中检索到的数据可能与存储在该列中数据不完全⼀样。
(6)货币数据表⽰正的或者负的货币数量。
  在 Microsoft SQL Server 中,货币数据的数据类型是Money 和 Smallmoney
  Money数据类型要求 8 个存储字节,Smallmoney 数据类型要求 4 个存储字节。
(7)特殊数据类型
  特殊数据类型包括前⾯没有提过的数据类型。特殊的数据类型有3种,即  Timestamp、Bit 和 Uniqueidentifier。
  Timestamp ⽤于表⽰SQL Server 活动的先后顺序,以⼆进投影的格式表⽰。Timestamp 数据与插⼊数据或者⽇期和时间没有关系。
  Bit 由 1 或者 0 组成。当表⽰真或者假、ON 或者 OFF 时,使⽤ Bit 数据类型。例如,询问是否是每⼀次访问的客户机请求可以存储在这种数据类型的列中。
  Uniqueidentifier 由 16 字节的⼗六进制数字组成,表⽰⼀个全局唯⼀的。当表的记录⾏要求唯⼀时,GUID是⾮常有⽤。例如,在客户标识号列使⽤这种数据类型可以区别不同的客户。
2.⽤户定义的数据类型
  ⽤户定义的数据类型基于在 Microsoft SQL Server 中提供的数据类型。当⼏个表中必须存储同⼀种数据类型时,并且为保证这些列有相同的数据类型、长度和可空性时,可以使⽤⽤户定义的数据类型。例如,可定义⼀种称为  postal_code 的数据类型,它基于 Char 数据类型。
  当创建⽤户定义的数据类型时,必须提供三个数:数据类型的名称、所基于的系统数据类型和数据类型的可空性。
(1)创建⽤户定义的数据类型
  创建⽤户定义的数据类型可以使⽤ Transact-SQL 语句。系统存储过程 sp_addtype 可以来创建⽤户定义的数据类型。其语法形式如下:
  sp_addtype {type},[,system_data_bype][,'null_type']
  其中,type 是⽤户定义的数据类型的名称。system_data_type 是系统提供的数据类型,例如 Decimal、Int、Char   等等。 null_type 表⽰该数据类型是如何处理空值的,必须使⽤单引号引起来,例如'NULL'、'NOT NULL'或者'NONULL'。
  例⼦:
  Use cust
  Exec sp_addtype ssn,'Varchar(11)',"Not Null'
  创建⼀个⽤户定义的数据类型 ssn,其基于的系统数据类型是变长为11 的字符,不允许空。
  例⼦:
  Use cust
  Exec sp_addtype birthday,datetime,'Null'
  创建⼀个⽤户定义的数据类型 birthday,其基于的系统数据类型是 DateTime,允许空。
  例⼦:
  Use master
  Exec sp_addtype telephone,'varchar(24),'Not Null'
  Eexc sp_addtype fax,'varchar(24)','Null'
  创建两个数据类型,即 telephone 和 fax
(2)删除⽤户定义的数据类型
  当⽤户定义的数据类型不需要时,可删除。删除⽤户定义的数据类型的命令是 sp_droptype {'type'}。
  例⼦:
  Use master
  Exec sp_droptype 'ssn'
  注意:当表中的列还正在使⽤⽤户定义的数据类型时,或者在其上⾯还绑定有默认或者规则时,这种⽤户定义的数据类型不能删除。
SQL SERVER的字段类型说明
  以下为SQL SERVER7.0以上版本的字段类型说明。SQL SERVER6.5的字段类型说明请参考SQL SERVER提供的说明。
字段类型描述
bit  0或1的整型数字
int  从-2^31(-2,147,483,648)到2^31(2,147,483,647)的整型数字
smallint  从-2^15(-32,768)到2^15(32,767)的整型数字
tinyint  从0到255的整型数字
decimal  从-10^38到10^38-1的定精度与有效位数的数字
numeric  decimal的同义词
money  从-2^63(-922,337,203,685,477.5808)到2^63-1(922,337,203,685,477.5807)的货币数据,最⼩货币单位千分之⼗
smallmoney  从-214,748.3648到214,748.3647的货币数据,最⼩货币单位千分之⼗
float  从-1.79E+308到1.79E+308可变精度的数字
real  从-3.04E+38到3.04E+38可变精度的数字
datetime  从1753年1⽉1⽇到9999年12⽇31的⽇期和时间数据,最⼩时间单位为百分之三秒或3.33毫秒
smalldatetime  从1900年1⽉1⽇到2079年6⽉6⽇的⽇期和时间数据,最⼩时间单位为分钟
timestamp  时间戳,⼀个数据库宽度的唯⼀数字
uniqueidentifier  全球唯⼀标识符GUID
char  定长⾮Unicode的字符型数据,最⼤长度为8000
varchar  变长⾮Unicode的字符型数据,最⼤长度为8000
text  变长⾮Unicode的字符型数据,最⼤长度为2^31-1(2G)
nchar  定长Unicode的字符型数据,最⼤长度为8000
nvarchar  变长Unicode的字符型数据,最⼤长度为8000
ntext  变长Unicode的字符型数据,最⼤长度为2^31-1(2G)
binary  定长⼆进制数据,最⼤长度为8000
varbinary  变长⼆进制数据,最⼤长度为8000
image  变长⼆进制数据,最⼤长度为2^31-1(2G)
-------------------------------------
Bit
1位,值为0或1
Int
Integer
4字节,值为-2^31~2^31-1
Smallint
2字节,值为-2^15~2^15-1
Tinyint
1字节,值为0~255
Decimal (p,s)
数字数据,固定精度为P,宽度为S
Numeric
Money
8字节,存放货币类型,值为-2^63~2^63-1
Small money
字符串是什么字段类型4字节,存放货币类型,值为-214748.3648~+214748.3647近似数值数据类型
Float (n)
N在1~24之间,4字节,7位精度
N=1~7为real
N在25~53之间,8字节,15位精度
=8~15为float
Datetime
8字节,描述某天的⽇期和时刻,值的精确度为1/300秒
Smalldatetime
4字节,描述某天的⽇期和时刻,精度为分钟
Cursor
对游标的引⽤
Timestamp
8字节,存放在数据库内唯⼀的数据
Uniqueidentifier
16字节,存放全局唯⼀标识(GUID)
Char (n)
⾮unicode字符串的固定长度,n=1~8000
Character (n)
Varchar (n)
可变长度,⾮unicode字符串n=1~8000
Char varying(n)
Text
服务器代码页中可变长度⾮unicode数据。最⼤长度为231-1个字符
Nchar
固定长度unicode字符串n=1~4000
National character (n),
National char(n)
Nvarchar
固定长度unicode字符串n=1~4000
National character varying(n)
Ntext
可变长度unicode数据,最⼤长度为230-1个字符
National text
Binary (n)
固定长度⼆进制数据,n在1~8000之间,存储空间为n+4字节
Varbinary (n)
可变长度⼆进制数据,n=1~8000
Binary varying (n)
Tmage
可变长度⼆进制数据,⼤⼩为0~231-1
注意:
1)对于数值型数据类型,宽度(scale)是指存储在⼩数点后的数字位数,⽽精度(precision)是指能存储的包含⼩数点在内的所有数字位数。    2) money和small money的存储宽度为4。
3)时间戳列值在每⼀⾏更新时系统⾃动更新,时间戳列不能是关键字或关键字的⼀部分。
4)唯⼀标识数据类型不能使⽤算术操作符(如+、-等),这种数据类型只能使⽤相等⽐较操作。Unicode是所有字符集的⼀致存储数据的标准。它要使⽤两倍于⾮Unicode数据存储的存储空间。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。