频道栏目
首页 > 资讯 > SQL Server > 正文

SQL Server 2008连载之数据类型

11-05-26        来源:[db:作者]  
收藏   我要投稿

精确数字类型

 

decimal[ (p[ , s] )] 和 numeric[ (p[ , s] )] 也称为带固定精度和小数位数的数值数据类型。

固定精度和小数位数。使用最大精度时,有效值从 - 10^38 +1 到 10^38 - 1 。

p (精度)最多可以存储的十进制数字的总位数,包括小数点左边和右边的位数。该精度必须是从 1 到最大精度 38 之间的值。默认精度为 18 。

s (小数位数)小数点右边可以存储的十进制数字的最大位数。小数位数必须是从 0 到 p 之间的值。仅在指定精度后才可以指定小数位数。默认的小数位数为 0 ;因此, 0 <= s <= p 。最大存储大小基于精度而变化。

 

 

近似数字

 

float [ ( n ) ]

其中 n 为用于存储 float 数值尾数的位数(以科学记数法表示),因此可以确定精度和存储大小。如果指定了 n ,则它必须是介于 1 和 53 之间的某个值。 n 的默认值为 53 。

 

 

日期和时间

 

字符串

 

其他数据类型

 

 

下面我们创建一张囊括几乎所有数据类型的表,然后根据

CREATE TABLE testDataType

(

  "bit"                 bit ,

  "tinyint"             tinyint ,

  "smallint"            smallint ,    

  "int"                 int ,    

  "bigint"              bigint ,      

  "decimal(p,s)"        decimal ( 10 , 4),

  "numeric(p,s)"        numeric ( 10 , 6),

  "smallmoney"          smallmoney ,  

  "money"               money ,       

  "float"               float ,

  "real"                real ,

  "datetime"            datetime ,      

  "date"                 date ,          

  "time"                time ,          

  "smalldatetime"       smalldatetime ,

  "datetime2"           datetime2 ,     

  "datetimeoffset"      datetimeoffset ,

  "char(n)"             char ( 4),       

  "varchar(n)"          varchar ( 4),    

  "nchar(n)"            nchar ( 4),      

  "nvarchar(n)"         nvarchar ( 4),   

  "binary(n)"           binary ( 6),     

  "varbinary(n)"        varbinary ( 6),  

  "varchar(max)"        varchar ( max ),  

  "nvarchar(max)"       nvarchar ( max ),

  "varbinary(max)"      varbinary ( max ),

  "Text"                Text ,          

  "Ntext"               Ntext ,         

  "Image"               Image         

)

-- 向各个字段插入相应的数据值

INSERT INTO testDataType (

  "bit" , "tinyint" , "smallint" , "int" , "bigint" ,

  "decimal(p,s)" , "numeric(p,s)" ,

  "smallmoney" , "money" ,

  "float" , "real" ,

  "datetime" , "date" , "time" ,

  "smalldatetime" , "datetime2" , "datetimeoffset" ,

  "char(n)" , "varchar(n)" , "nchar(n)" , "nvarchar(n)" ,

  "binary(n)" , "varbinary(n)" ,

  "varchar(max)" , "nvarchar(max)" , "varbinary(max)" ,

  "Text" , "Ntext" , "Image"

)

SELECT

  1, 123, 12345, 1234567890, 1234567890123456789,

  987654.3210, 9876.543210,

  123456.7890, 123456789012345.6789,

  1234567890.1234567890, 1234567890.1234567890,

  2010-01-01 23:59:59.123 , 2010-01-01 , 23:59:59. 1234567 ,

  2010-01-01 23:59:59 , 2010-01-01 23:59:59.1234567 , 2010-01-01 23:59:59.1234567 +12:00 ,

  abcd , abcd , 王保强 , 王保强 ,

  CONVERT ( BINARY , 123456 ), CONVERT ( BINARY , 123456 ),

  1234567890 , 1234567890 , CONVERT ( BINARY , 1234567890 ),

  1234567890 , 1234567890 , 1234567890

-- 使用 system_internals_allocation_units 来获取该表的相关数据页

SELECT c . name , a . type_desc ,

       total_pages , used_pages , data_pages ,

       testdb . dbo . f_get_page ( first_page ) first_page_address ,

       testdb . dbo . f_get_page ( root_page ) root_address ,

       testdb . dbo . f_get_page ( first_iam_page ) IAM_address

  FROM sys . system_internals_allocation_units a , sys . partitions b , sys . objects c

  WHERE a . container_id = b . partition_id

相关TAG标签
上一篇:SQL Server2008存储结构之非聚集索引
下一篇:SQL server2005+SP3的死锁诊断过程
相关文章
图文推荐

关于我们 | 联系我们 | 广告服务 | 投资合作 | 版权申明 | 在线帮助 | 网站地图 | 作品发布 | Vip技术培训 | 举报中心

版权所有: 红黑联盟--致力于做实用的IT技术学习网站