sql server资料

| 1 Comment | No TrackBacks

第一个表说明对于所有   Microsoft®   SQL   Server™   2000   版本都相同的最大容量。第二个和第三个表说明因   SQL   Server   2000   的版本和操作系统的不同而异的容量。   

下表说明在   Microsoft   SQL   Server   数据库中定义的,或在   Transact-SQL   语句中引用的各种对象的最大值(数量或大小)。下表不包含   Microsoft®   SQL   Server   2000™   Windows®   CE   版。  
   
  最大值(数量或大小)    
  对象         SQL   Server   7.0             SQL   Server   2000    
  批处理大小   65,536   *   网络数据包大小1   65,536   *   网络数据包大小1    
  每个短字符串列的字节数   8,000   8,000    
  每个   text、ntext、或   image   列的字节数   2   GB-2   2   GB-2    
  每个   GROUP   BY、ORDER   BY的字节数   8,060        
  每个索引中的字节数   900   9002    
  每个外键的字节数   900   900    
  每个主键的字节数   900   900    
  每行字节数   8,060   8,060    
  存储过程源文本中的字节数   批处理大小之较小者或者   250   MB   批处理大小之较小者或者   250   MB    
  每个数据表的聚集索引数   1   1    
  GROUP   BY、ORDER   BY   中的列数   只受字节数限制      
  GROUP   BY   WITH   CUBE   或   WITH   ROLLUP   语句中的列数或表达式数目   10      
  每个索引的列数   16   16    
  每个外键的列数   16   16    
  每个主键的列数   16   16    
  每个基础数据表的列数   1,024   1,024    
  每个SELECT   语句的列数   4,096   4,096  
  每个INSERT   语句的列数   1,024   1,024    
  每个客户端的连接个数   已配置连接的最大值   已配置连接的最大值    
  数据库大小   1,048,516   TB3   1,048,516   TB3    
  每个   SQL   Server   实例的数据库个数   32,767   32,767    
  每个数据库的文件组个数   256   256    
  每个数据库的文件个数   32,767   32,767    
  文件大小(数据)   32   TB   32   TB    
  文件大小(日志)   4   TB   32   TB    
  每个数据表的外键表引用   253   253    
  标识符长度(以字符计)   128   128    
  每台计算机的实例数   暂缺   16    
  包含   SQL   语句的字符串长度(批处理大小)   65,536   *   网络数据包大小1   65,536   *   网络数据包大小1    
  每个连接的锁数   每个服务器的最大锁数   每个服务器的最大锁数    
  每个   SQL   Server   实例的锁数   2,147,483,647(静态)  
  SQL   Server   40%   的内存(动态)   2,147,483,647(静态)  
  SQL   Server   40%   的内存(动态)    
  嵌套存储过程层数   32   32    
  嵌套子查询   32   32    
  嵌套触发器层数   32   32    
  每个数据表的非聚集索引个数   249   249    
  SQL   Server   实例中同时打开的对象个数4   2,147,483,647(或可用内存)   2,147,483,647(或可用内存)    
  每个数据库中的对象个数   2,147,483,6474   2,147,483,6474    
  每个存储过程的参数个数   1,024   1,024    
  每个数据表的   REFERENCE   个数   253   253    
  每个数据表的行数   受可用存储资源限制   受可用存储资源限制    
  每个数据库的数据表个数   受数据库中的对象个数限制4   受数据库中的对象个数限制4    
  每个   SELECT   语句的数据表个数   256   256    
  每个数据表的触发器个数   受数据库中的对象个数限制4   受数据库中的对象个数限制4    
  每个数据表的   UNIQUE   索引个数或约束个数   249个非聚集索引和   1   个聚集索引   249个非聚集索引和   1   个聚集索引 
   
  1   网络数据包大小是表格格式数据方案   (TDS)   数据包的大小,该数据包用于应用程序和关系数据库引擎之间的通讯。默认的数据包大小为   4   KB,由   network   packet   size   配置选项控制。  
  2   在   SQL   Server   2000   中,任何键的最大字节数不能超过   900。可以使用可变长度的列来定义键,只要在这种列中不插入数据超过   900   字节的行,其最大大小就可以在   900   以上。有关更多信息,请参见索引键的最大值。  
  3   当使用   SQL   Server   2000   Desktop   Engine   或   Microsoft   数据引擎   (MSDE)   1.0   时,数据库的大小不能超过   2   GB。  
  4数据库对象包括所有的表、视图、存储过程、扩展存储过程、触发器、规则、默认值及约束。一个数据库中所有对象的总数不得超过   2,147,483,647。
   
  说明     SQL   Server   2000   中文版不支持英文版的   NT   4.0   企业版。  
   
  SQL   Server   2000   版本支持的最大处理器数  
  下表列出各   SQL   Server   2000   版本中的数据库引擎在对称多处理   (SMP)   计算机上能够支持的处理器数。
   
  操作系统   企业版   标准版   个人版   开发版   Desktop   Engine   SQL   Server   CE   企业评估版    
  Microsoft   Windows®   2000   DataCenter   32   4   2   32   2   暂缺   32    
  Windows   2000   Advanced   Server   8   4   2   8   2   暂缺   8    
  Windows   2000   Server   4   4   2   4   2   暂缺   4    
  Windows   2000   Professional   暂缺   暂缺   2   2   2   暂缺   2    
  Microsoft   Windows   NT®   4.0   Server   企业版   8   8   2   8   2   暂缺   8    
  Windows   NT   4.0   Server   4   4   2   4   2   暂缺   4    
  Windows   NT   4.0   Workstation   暂缺   暂缺   2   2   2   暂缺   2    
  Microsoft   Windows   98   暂缺   暂缺   1   使用   Desktop   Engine   1   暂缺   暂缺    
  Microsoft   Windows   CE   暂缺   暂缺   暂缺   暂缺   暂缺   1   暂缺
   
  SQL   Server   2000   版本支持的最大物理内存量  
  下表列出各   SQL   Server   2000   版中的数据引擎能够支持的最大物理内存量或   RAM。  
   
  操作系统   企业版   标准版   个人版   开发版   Desktop   Engine   SQL   Server   CE   企业评估版    
  Windows   2000   DataCenter   64   GB   2   GB   2   GB   64   GB   2   GB   暂缺   64   GB    
  Windows   2000   Advanced   Server   8   GB   2   GB   2   GB   8   GB   2   GB   暂缺   8   GB    
  Windows   2000   Server   4   GB   2   GB   2   GB   4   GB   2   GB   暂缺   4   GB    
  Windows   2000   Professional   暂缺   暂缺   2   GB   2   GB   2   GB   暂缺   2   GB    
  Windows   NT   4.0   Server   企业版   3   GB   2   GB   2   GB   3   GB   2   GB   暂缺   3   GB    
  Windows   NT   4.0   Server   2   GB   2   GB   2   GB   2   GB   2   GB   暂缺   2   GB    
  Windows   NT   4.0   Workstation   暂缺   暂缺   2   GB   2   GB   2   GB   暂缺   2   GB


在 Microsoft® SQL Server™ 中,每个列、局部变量、表达式和参数都有一个相关的数据类型,这是指定对象可持有的数据类型(整型、字符、money 等等)的特性。SQL Server 提供系统数据类型集,定义了可与 SQL Server 一起使用的所有数据类型。下面列出系统提供的数据类型集。


可以定义用户定义的数据类型,其是系统提供的数据类型的别名。有关用户定义的数据类型的更多信息,请参见 sp_addtype创建用户定义的数据类型


当两个具有不同数据类型、排序规则、精度、小数位数或长度的表达式通过运算符进行组合时:



  1. 通过将数据类型的优先顺序规则应用到输入表达式的数据类型来确定所得值的数据类型。有关更多信息,请参见数据类型的优先顺序


  2. 如果结果数据类型为 charvarchartextncharnvarcharntext,则结果值的排序规则由排序规则的优先顺序规则决定。有关更多信息,请参见排序规则的优先顺序


  3. 结果的精度、小数位数及长度取决于输入表达式的精度、小数位数及长度。有关更多信息,请参见精度、小数位数和长度


SQL Server 为 SQL-92 兼容性提供了数据类型同义词。有关更多信息,请参见数据类型同义词


精确数字

整数

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

bit


1 或 0 的整数数据。


decimal 和 numeric

decimal


从 -10^38 +1 到 10^38 –1 的固定精度和小数位的数字数据。


numeric


功能上等同于 decimal


money 和 smallmoney

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.40E + 38 到 3.40E + 38 的浮点精度数字。


datetime 和 smalldatetime

datetime


从 1753 年 1 月 1 日到 9999 年 12 月 31 日的日期和时间数据,精确到百分之三秒(或 3.33 毫秒)。


smalldatetime


从 1900 年 1 月 1 日到 2079 年 6 月 6 日的日期和时间数据,精确到分钟。


字符串

char


固定长度的非 Unicode 字符数据,最大长度为 8,000 个字符。


varchar


可变长度的非 Unicode 数据,最长为 8,000 个字符。


text


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


Unicode 字符串

nchar


固定长度的 Unicode 数据,最大长度为 4,000 个字符。


nvarchar


可变长度 Unicode 数据,其最大长度为 4,000 字符。sysname 是系统提供用户定义的数据类型,在功能上等同于 nvarchar(128),用于引用数据库对象名。


ntext


可变长度 Unicode 数据,其最大长度为 2^30 - 1 (1,073,741,823) 个字符。


二进制字符串

binary


固定长度的二进制数据,其最大长度为 8,000 个字节。


varbinary


可变长度的二进制数据,其最大长度为 8,000 个字节。


image


可变长度的二进制数据,其最大长度为 2^31 - 1 (2,147,483,647) 个字节。


其它数据类型

cursor


游标的引用。


sql_variant


一种存储 SQL Server 支持的各种数据类型(textntexttimestampsql_variant 除外)值的数据类型。


table


一种特殊的数据类型,存储供以后处理的结果集。


timestamp


数据库范围的唯一数字,每次更新行时也进行更新。


uniqueidentifier


全局唯一标识符 (GUID)。



optimize SQLSERVER 3数据类型的考虑


分类:SQLSERVER




l  decimalnumeric中尽量选用decimal,numeric只是为了向后兼容。


l  bigint,int,smallint,tinyint


首先int,空间占用合适,运算速度快;(2147,...,...2个多亿)


如果非常在意空间的话,考虑tinyint


超大应用场合,考虑bigint


l money,smallmoney


尽量考虑用decimal替代,原因:性能稍稍好一些;相对其它数据库兼容性好。


money的好处是可以用到某些货币运算函数。


float类型尽量少用,性能不好,精度不高,一般只用于科学计算。


l  char,varchar,nchar/nvarchar


char性能好;varchar节省空间;选择方法:10个字节以上的用varchar


n类型的占用空间大,性能低,如果不准备存中文或中亚文字则尽量避免使用。


尤其向类似工号的字段更不要使用n类型,首先它不会存入中文,其次它可能作为索引,此时对性能的影响就更大。


l  text/image  考虑到维护方便、效率以及程序开发的方便性,最好不用,即不将其存入数据库中;采用varchar指向其相应的存储路径。


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。  

  (5)float和real

  float:从-1.79^308到1.79^308之间的浮点数字数据。

  real:从-3.40^38到3.40^38之间的浮点数字数据。在SQL Server中,real的同义词为float(24)。






1.SQL SERVER的数据类型


数据类弄是数据的一种属性,表示数据所表示信息的类型。任何一种计算机语言都定义了自己的数据类型。当然,不同的程序语言都具有不同的特点,所定义的数据类型的各类和名称都或多或少有些不同。SQLServer 提供了 25 种数据类型:
  ·Binary [(n)]
  ·Varbinary [(n)]
  ·Char [(n)]
  ·Varchar[(n)]
  ·Nchar[(n)]
  ·Nvarchar[(n)]
  ·Datetime
  ·Smalldatetime
  ·Decimal[(p[,s])]
  ·Numeric[(p[,s])]
  ·Float[(n)]
  ·Real
  ·Int
  ·Smallint
  ·Tinyint
  ·Money
  ·Smallmoney
  ·Bit
  ·Cursor
  ·Sysname
  ·Timestamp
  ·Uniqueidentifier
  ·Text
  ·Image
  ·Ntext

(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 和 DYM。在默认情况下,日期格式为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'
  注意:当表中的列还正在使用用户定义的数据类型时,或者在其上面还绑定有默认或者规则时,这种用户定义的数据类型不能删除。

容易混淆的数据类型


bigint 从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型数据(所有数字)。存储大小为 8 个字节。


int 从 -2^31 (-2,147,483,648) 到 2^31 - 1 (2,147,483,647) 的整型数据(所有数字)。存储大小为 4 个字节。int 的 SQL-92 同义字为 integer。


smallint 从 -2^15 (-32,768) 到 2^15 - 1 (32,767) 的整型数据。存储大小为 2 个字节。


tinyint 从 0 到 255 的整型数据。存储大小为 1 字节。


在支持整数值的地方支持 bigint 数据类型。但是,bigint 用于某些特殊的情况,当整数值超过 int 数据类型支持的范围时,就可以采用 bigint。


在 SQL Server 中,int 数据类型是主要的整数数据类型。 在数据类型优先次序表中,bigint 位于 smallmoney 和 int 之间。 只有当参数表达式是 bigint 数据类型时,函数才返回 bigint。SQL Server 不会自动将其它整数数据类型(tinyint、smallint 和 int)提升为 bigint。


No TrackBacks

TrackBack URL: http://www.wujianrong.com/mt-tb.cgi/2116

1 Comment

很详细,受益非浅。。。

Leave a comment

相关文档

上一篇:web3.0, Paris .

下一篇:软件业盈利能力增强 新兴市场需求旺盛