sql server 数据类型介绍

SQL Server的数据类型介绍SQL

数据类型是数据的一种属性,表示数据所表示信息的类型。任何一种计算机语言都定义了自己的数据类型。当然,不同的程序语言都具有不同的特点,所定义的数据类型的各类和名称都或多或少有些不同。

系统原有的数据类型

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是非常有用。例如,在客户标识号列使用这种数据类型可以区别不同的客户。

用户定义的数据类型
      
用户定义的数据类型基于在 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‘

注意:当表中的列还正在使用用户定义的数据类型时,或者在其上面还绑定有默认或者规则时,这种用户定义的数据类型不能删除。

时间: 2024-12-29 11:55:19

sql server 数据类型介绍的相关文章

SQL Server数据类型介绍

简单整理几个常用的SQL server 数据类型的描述,以便查阅. 原文地址:https://blog.51cto.com/14154700/2371421

SQL Server数据类型,System.Data.SqlDbType,.NET数据类型

SQL Server数据类型 System.Data.SqlDbType .NET数据类型 int SqlDbType.Int int varchar SqlDbType.VarChar string bit SqlDbType.Bit bool datetime SqlDbType.DateTime DateTime decimal SqlDbType.Decimal Decimal float SqlDbType.Float Double image SqlDbType.Image Byte

整理sql server数据类型

我们在平常开发过程中,在设计数据的时候,经常碰到数据类型选择的问题,为了更快,更合适地选择正确的数据类型,所以在这里做个总结. 分类 sql server 数据类型 c# 数据类型 描述 应用场景 字符和字符串 char(n) string 固定长度的字符串,最多存储8000个字符     nchar(n) string 固定长度的unicode数据,最多4000个字符     varchar(n) string 可变长度的字符串,最多存储8000个字符 [常用],表示字符串,不包含中文.  

MySql和SQL Server数据类型 对比

My Sql 数据类型 SQL Server 数据类型 Yes/No bit Smallint(字节型) tinyint Integer(长整型) int Real(单精度浮点型)    real Float(双精度浮点型) float Currency money smallmoney    Decimal/numeric decimal numeric    Date/Time datetime smalldatetime AutoNumber(增量) int(带有定义的 Identity

为更好地设计数据库,重新整理sql server数据类型

我们在平常开发过程中,在设计数据的时候,经常碰到数据类型选择的问题,为了更快,更合适地选择正确的数据类型,所以在这里做个总结. 分类 sql server 数据类型 c# 数据类型 描述 应用场景 字符和字符串 char(n) string 固定长度的字符串,最多存储8000个字符     nchar(n) string 固定长度的unicode数据,最多4000个字符     varchar(n) string 可变长度的字符串,最多存储8000个字符 [常用],表示字符串,不包含中文.  

SQL Server 数据类型映射 (ADO.NET)

http://msdn.microsoft.com/zh-cn/library/cc716729(VS.90).aspx   SQL Server 数据类型映射 (ADO.NET) .NET Framework 3.5 其他版本 3(共 3)对本文的评价是有帮助 - 评价此主题 更新:November 2007 SQL Server 和 .NET Framework 基于不同的类型系统.例如,.NET Framework Decimal 结构的最大小数位数为 28,而 SQL Server 的

SQL SERVER 数据类型详解(SQL Server 2008)

数据类型类别 SQL Server 中的数据类型归纳为下列类别: 数字类型 1.精确数字 2.近似数字 3.日期和时间 字符串类型 4.非Unicode字符串 4.Unicode字符串 5.二进制字符串 6.其他数据类型 7.CLR 在 SQL Server 中,根据其存储特征,某些数据类型被指定为属于下列各组: 大值数据类型:varchar(max).nvarchar(max) 和 varbinary(max) 大型对象数据类型:text.ntext.image.varchar(max).nv

8.8SQL Server数据类型介绍1

image类型:存储二进制字节数组. (相当于C#中的byte[]字节类型) sql server常用的数据类型 1.image类型,用来存储byte[](字节). 2.字符串类型 char nchar varchar nvarchar text ntext varchar(max) nvarchar(max) 以上这些数据类型都是表示字符串. ----------------------------------------------------------------------------

SQL Server 全文索引介绍(转载)

概述 全文引擎使用全文索引中的信息来编译可快速搜索表中的特定词或词组的全文查询.全文索引将有关重要的词及其位置的信息存储在数据库表的一列或多列中.全文索引是一种特殊类型的基于标记的功能性索引,它是由 SQL Server 全文引擎生成和维护的.生成全文索引的过程不同于生成其他类型的索引.全文引擎并非基于特定行中存储的值来构造 B 树结构,而是基于要编制索引的文本中的各个标记来生成倒排.堆积且压缩的索引结构.在 SQL Server 2008 中,全文索引大小仅受运行 SQL Server 实例的