`

转 sql server 2005的数据类型

阅读更多
sql server 2005的数据类型与sql 2000有一些不同,在创建表时,列的数据类型需要注意几点
  • 用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列的索引。

找到这些资料是因为在存储过程里面定义局部变量的时候使用ntext,text,image类型的会出现错误。把问题发到郑州俱乐部的群里面,大家真当作一回事情讨论了一番。本来还以为定义成varchar (max),那么原有的text类型的数据会不会给截断了,原来不会出现这样的事情。

1.sql server的数据类型

数据类弄是数据的一种属性,表示数据所表示信息的类型。任何一种计算机语言都定义了自己的数据类型。当然,不同的程序语言都具有不同的特点,所定义的数据类型的各类和名称都或多或少有些不同。sqlserver 提供了 25 种数据类型:
·binary
·varbinary
·char
·varchar
·nchar
·nvarchar
·datetime
·smalldatetime
·decimal
·numeric
·float
·real
·int
·smallint
·tinyint
·money
·smallmoney
·bit
·cursor
·sysname
·timestamp
·uniqueidentifier
·text
·image
·ntext

(1)二进制数据类型

二进制数据包括 binary、varbinary 和 image
binary 数据类型既可以是固定长度的(binary),也可以是变长度的。
binary 是 n 位固定的二进制数据。其中,n 的取值范围是从 1 到 8000。其存储窨的大小是 n + 4 个字节。
varbinary 是 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},
其中,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"
注意:当表中的列还正在使用用户定义的数据类型时,或者在其上面还绑定有默认或者规则时,这种用户定义的数据类型不能删除

序号 类别 sqlserver c sharp 备注
1 整数 bit boolean true转换为1false转换为0
2 tinyint byte c sharp 数据类型都位于system命名空间
3 smallint int16
4 int int32
5 bigint int64
6 smallmoney decimal
7 money decimal
8 numeric decimal
9 decimal decimal
10 浮点数 float double
11 real single
12 日期和时间 smalldatetime datetime
13 datetime datetime
14 timestamp datetime
15 字符串 char string
16 text string
17 varchar string
18 nchar string
19 ntext string
20 nvarchar string
21 二进制数据 binary byte[]
22 varbinary byte[]
23 image byte[]
24 其他 uniqueidentifier guid
25 variant object

打开SQL Server 2005的管理工具,选中需要创建存储过程的数据库,找到“可编程性”,展开后可以看到“存储过程"

分享到:
评论

相关推荐

    SQL SERVER的数据类型自定义

    ### SQL Server 数据类型详解与自定义数据类型创建 在数据库设计与管理中,理解并熟练掌握数据类型至关重要,因为它们直接影响到数据存储的效率、安全性和查询性能。SQL Server 提供了丰富的内置数据类型,同时也...

    SqlServer数据库的数据类型

    ### SqlServer数据库的数据类型详解 数据类型在编程与数据库管理中扮演着至关重要的角色,它不仅定义了数据的存储方式,还决定了数据可以执行的操作。SQL Server作为一种广泛使用的数据库管理系统,提供了丰富的...

    sqlserver数据库类型对应Java中的数据类型

    SQL Server 数据库类型对应 Java 中的数据类型 SQL Server 是一个关系数据库管理系统,Java 是一个广泛使用的编程语言。在 Java 中,对数据库的操作需要通过 JDBC(Java Database Connectivity)来实现,而在 JDBC ...

    Microsoft SQL Server 2005 向后兼容组件SQLServer2005_BC.msi

    SQLServer2005_BC.msi 文件是这个向后兼容组件的安装程序,它包含了用于在更新的SQL Server环境中模拟SQL Server 2005环境的特定库和接口。安装此组件后,用户可以继续使用那些设计时依赖SQL Server 2005特性的应用...

    SQL Server 2005 数据类型和.Net数据类型的对应关系.doc

    SQL Server 2005 和 .NET Framework 之间的数据类型对应关系是开发数据库应用程序时的重要基础知识。理解这些对应关系有助于确保在SQL Server中存储的数据能够正确地被.NET应用程序读取和处理。以下是对两种数据类型...

    sql server 2005数据类型说明

    在SQL Server 2005中,数据类型的丰富性和灵活性为数据库设计提供了强大的支持,能够满足各种业务场景的需求。以下是对部分关键数据类型及其特性的深入解析: ### 1. 字符串类型 #### `char` 和 `varchar` - `...

    SQLServer2005_BC.msi SQLServer2005及以后版本 向前 兼容 DTS等功能

    在"SQLServer2005_BC.msi"这个安装程序中,包含了x86、x64和ia64三种架构的版本,这意味着无论是在32位、64位还是Itanium架构的系统上,都可以进行安装和运行。这种跨平台的兼容性使得用户能够在各种不同的硬件环境...

    SQLServer2000数据类型.doc

    SQLServer2000数据类型 varchar number

    sql server 2005 完美转sql server 2000,无错正常运行

    例如,2005中的新数据类型如FILESTREAM、HIERARCHYID,或者高级的T-SQL函数,可能在2000中无法识别。另外,索引、触发器、存储过程的创建语句也可能存在版本差异。 为了解决这些问题,通常需要采取以下策略: 1. *...

    SQL Server 2000数据类型

    SQL Server 2000 是一个关系型数据库管理系统,它提供了丰富的数据类型来支持各种不同种类的数据存储。数据类型是数据库设计的基础,它定义了数据的结构和含义。本章将详细阐述SQL Server 2000 中的主要数据类型。 ...

    SQLServer2005_BC.zip

    6. **安装指南**:压缩包中的"SQLServer2005_BC_x64.msi"和"SQLServer2005_BC.msi"是安装程序文件,分别对应64位和32位操作系统。安装过程中,用户需要按照向导提示配置安装选项,如选择安装组件、设置服务账户和...

    SQLServer2005数据挖掘与商业智能完全解决方案

    《SQLServer2005数据挖掘与商业智能完全解决方案》一书主要探讨如何利用SQL Server 2005构建商业智能应用,以满足日益复杂的商业需求。书中以FoodMart数据库为例,展示了如何从传统的业务数据中提取有价值的信息,...

    SQLServer2005_SSMSEE_x64.rar

    标题中的"SQLServer2005_SSMSEE_x64.rar"表明这是一个关于Microsoft SQL Server 2005的管理工具,特别指出是64位版本,并且是压缩包文件。描述中的“2005 管理工具”进一步确认了这个文件是用于管理和维护SQL Server...

    SQL Server 2005盛宴系列之六:新的选择――SQL Server Express 2005.zip

    它引入了诸多新功能,如增强的查询性能、改进的安全性、支持XML数据类型以及集成的服务,如Analysis Services(用于数据仓库和商务智能)、Reporting Services(报表服务)和Integration Services(数据集成服务)。...

    sqlserver 2005 express X64

    - 表设计:掌握如何定义表结构,包括字段、数据类型、主键和外键。 - 查询语言:学习T-SQL,包括SELECT、INSERT、UPDATE和DELETE语句。 - 触发器和存储过程:理解如何编写和使用触发器及存储过程来实现业务逻辑。...

    如何将SQL Server 2005升级到SQL Server 2008

    1. SQL Server 2008新特性:升级前,首先需要了解SQL Server 2008新增加的功能,如新的数据类型、新的Transact-SQL特性、管理工具改进等。这不仅包括对数据库开发者和数据库管理员(DBA)友好的改进,还包括对数据...

    SQL2005精简版一键安装 sql server2005一键安装

    SQL Server 2005是微软公司推出的一款关系型数据库管理系统,它在企业级数据管理、分析和报告方面表现出色。这款产品提供了多种版本,包括精简版(Express Edition),适用于小型企业和个人开发者,提供了基本的...

    SQL server2005(百度云下载哦)包含64位和32位的安装包

    1. **增强的数据库引擎**:SQL Server 2005的Transact-SQL引擎进行了优化,提供更快的查询性能和更高的并发处理能力,同时支持更多的数据类型和新的T-SQL函数。 2. **集成的服务**:SQL Server 2005集成了多个服务...

    sql server 数据类型

    SQL Server 数据类型是数据库管理系统中用于定义和存储数据的基础组件,它们决定了数据的结构和特性。在SQL Server 2000中,数据类型的选择至关重要,因为它直接影响到数据的存储方式、大小以及处理效率。 首先,让...

    sqlserver2005 JDBC驱动程序JAR包

    **SQLServer2005 JDBC驱动程序JAR包详解** SQLServer2005 JDBC驱动程序是用于在Java应用程序中连接到Microsoft SQL Server 2005数据库的关键组件。JDBC(Java Database Connectivity)是一种Java API,允许Java...

Global site tag (gtag.js) - Google Analytics