设为首页 收藏本站
查看: 762|回复: 0

[经验分享] 转 sql server 2005的数据类型

[复制链接]

尚未签到

发表于 2016-11-1 00:16:26 | 显示全部楼层 |阅读模式
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"
注意:当表中的列还正在使用用户定义的数据类型时,或者在其上面还绑定有默认或者规则时,这种用户定义的数据类型不能删除
序号类别sqlserverc sharp备注
1整数bitbooleantrue转换为1false转换为0
2tinyintbytec sharp 数据类型都位于system命名空间
3smallintint16
4intint32
5bigintint64
6smallmoneydecimal
7moneydecimal
8numericdecimal
9decimaldecimal
10浮点数floatdouble
11realsingle
12日期和时间smalldatetimedatetime
13datetimedatetime
14timestampdatetime
15字符串charstring
16textstring
17varcharstring
18ncharstring
19ntextstring
20nvarcharstring
21二进制数据binarybyte[]
22varbinarybyte[]
23imagebyte[]
24其他uniqueidentifierguid
25variantobject




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

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-293786-1-1.html 上篇帖子: SQL SERVER 2005数据库镜像(中) 下篇帖子: 如何处理SQL Server死锁问题
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表