- 1、本文档共8页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
SQL用户自定义数据类型-规则-默认
用户自定义的数据类型、默认值、规则
一、用户自定义的数据类型
用户自定义数据类型可看做是系统数据类型的别名。
在多表操作的情况下,当多个表中的列要存储相同类型的数据时,往往要确保这些列具有完全相同的数据类型、长度和为空性(数据类型是否允许为空)。例如,对于student数据库中表student、grade和course三张表的xh,kh两个列必须具有相同的数据类型。
创建用户自定义数据类型时首先应考虑如下三个属性:
(1)数据类型名称
(2)新数据类型所依据的系统数据类型(又称为基类型)
(3)为空性
如果为空性未明确定义,系统将依据数据库或连接的ANSI NULL默认设置进行指派。
1、创建用户自定义数据类型的方法如下:
(1)利用企业管理器定义
(2)利用SQL命令定义数据类型
在SQL Server中,通过系统存储过程实现用户数据类型的定义。
语法格式如下:
sp_addtype [@typename=] type, /*自定义类型名称*/
[@phystype=] system_data_type /*基类型*/
[,[@nulltype=] null_type /*为空性*/
[,[@owner=] owner_name] /*创建者或所有者*/
其中:
type:用户自定义数据类型的名称。
System_data_type:用户自定义数据类型所依据的基类型。如果参数中嵌入有空格或标点符号,则必须用引号将该参数引起来。
null_type:指明用户自定义数据类型处理空值的方式。取值可为’NULL’、’NOT NULL’、’NONULL’三者之一(注意:必须用单引号引起来)。如果没有用sp_addtype显式定义null_type,则将其设置为当前默认值,系统默认值一般为’NULL’。
例:定义学号字段的数据类型
sp_addtype ’student_xh’,’char(4)’,’not null’
2、删除用户自定义数据类型
(1)利用企业管理器
(2)利用SQL语句
语法格式如下:
sp_droptype [@typename=] type
其中type为用户自定义数据类型的名称,应用单引号括起来。
例:删除student_xh用户自定义数据类型
sp_droptype ’student_xh’
说明:
(1)如果在表定义内使用某个用户定义的数据类型,或者将某个规则或默认值绑定到这种数据类型,则不能删除该类型。
(2)要删除一用户自定义类型,该数据类型必须存在,否则返回一条错误信息。
3、执行权限
执行权限默认授予sysadmin固定服务器角色、db_ddladmin和db_owner固定数据库角色成员以及数据类型所有者。
4、利用自定义数据类型定义字段
用户自定义数据类型与基类型一样使用,可定义为字段的数据类型。
二、默认值对象的定义、使用与删除
默认值对象的定义、使用与删除既可利用企业管理器实现,也可利用SQL语句实现。
1、通过企业管理器定义和绑定DEFAULT默认值对象
2、通过SQL语句定义和绑定DEFAULT默认值对象
(1)通过SQL语句定义DEFAULT默认值对象
命令格式如下:
CREATE DEFAULT 默认值名称 AS 常量表达式
常量表达式可以含有常量、内置函数、字符和日期常量用单引号引起来;货币、整数和浮点常量不需要使用引号。十六进制数据必须以0x开头,货币数据必须以美元符号($)开头。默认值对象必须与列数据类型兼容。
例:定义学分默认值
CREATE DEFAULT COURSE_XF AS 0
(2)通过系统存储过程绑定DEFAULT默认值对象
创建默认值对象后,要使其作用,应使用sp_bindefault存储过程将其绑定到列或用户自定义数据类型。
语法格式如下:
sp_bindefault [@defname=]’默认值对象名’,
[@objname=]’被绑定对象的名称’
[,[@futureonly=]’futureonly_flag’]
其中参数futureonly_flag仅在将默
文档评论(0)