用户自定义的数据类型、默认值、规则
一、用户自定义的数据类型
用户自定义数据类型可看做是系统数据类型的别名。
在多表操作的情况下,当多个表中的列要存储相同类型的数据
时,往往要确保这些列具有完全相同的数据类型、长度和为空性(数据类型是否允许为空)。例如,对于stude nt数据库中表stude nt、grade和c ourse三张表的xh,kh两个列必须具有相同的数据类型。
创建用户自定义数据类型时首先应考虑如下三个属性:
(1)数据类型名称
(2)新数据类型所依据的系统数据类型(又称为基类型)
(3)为空性
如果为空性未明确定义,系统将依据数据库或连接的A N SI NULL 默认设置进行指派。
1、创建用户自定义数据类型的方法如下:
(1)利用企业管理器定义
(2)利用SQL命令定义数据类型
在SQL Server中,通过系统存储过程实现用户数据类型的定义。
语法格式如下:
sp_addt ype [@typenam e=] type, /*自定义类型名称*/ [@phystyp e=] system_data_t ype /*基类型*/
[,[@nulltyp e=] null_ty pe /*为空性*/
[,[@owner=] owner_n ame] /*创建者或所有者*/其中:
type:用户自定义数据类型的名称。
System_data_t ype:用户自定义数据类型所依据的基类型。如果参数中嵌入有空格或标点符号,则必须用引号将该参数引起来。 null_ty pe:指明用户自定义数据类型处理空值的方式。取值可为’NULL’、’NOT NULL’、’NONULL’三者之一(注意:必须用单引号引起来)。如果没有用sp_addty pe显式定义null_t ype,则将其设置为当前默认值,系统默认值一般为’NULL’。
例:定义学号字段的数据类型
sp_addt ype ’student_xh’,’char(4)’,’not null’
2、删除用户自定义数据类型
(1)利用企业管理器
(2)利用SQL语句
语法格式如下:
sp_drop type [@typenam e=] type
其中type为用户自定义数据类型的名称,应用单引号括起来。
例:删除student_xh用户自定义数据类型
sp_drop type ’student_xh’
说明:
(1)如果在表定义内使用某个用户定义的数据类型,或者将
某个规则或默认值绑定到这种数据类型,则不能删除该类型。
(2)要删除一用户自定义类型,该数据类型必须存在,否则返回一条错误信息。
3、执行权限
执行权限默认授予sysad min固定服务器角、db_ddla dmin 和d b_owne r固定数据库角成员以及数据类型所有者。
4、利用自定义数据类型定义字段
用户自定义数据类型与基类型一样使用,可定义为字段的数据类型。
二、默认值对象的定义、使用与删除
默认值对象的定义、使用与删除既可利用企业管理器实现,也可利用SQL语句实现。
1、通过企业管理器定义和绑定D E FAULT默认值对象
2、通过SQL语句定义和绑定D E FAULT默认值对象
(1)通过SQL语句定义DEFA ULT默认值对象
命令格式如下:
CREATEDEFAULT默认值名称 AS 常量表达式
常量表达式可以含有常量、内置函数、字符和日期常量用单引号引起来;货币、整数和浮点常量不需要使用引号。十六进制数据必须以0x开头,货币数据必须以美元符号($)开头。默认值对象必
须与列数据类型兼容。
例:定义学分默认值
CREATEDEFAULT COURSE_XF AS 0
(2)通过系统存储过程绑定DEF AULT默认值对象
创建默认值对象后,要使其作用,应使用sp_bindefa ult存储过程将其绑定到列或用户自定义数据类型。
语法格式如下:
sp_bind efault [@defname=]’默认值对象名’,
[@objname=]’被绑定对象的名称’
[,[@futureo nly=]’futureo nly_fl ag’]
其中参数futureonl y_flag仅在将默认值对象绑定到用户定义数据类型时才使用,当futureonly_f lag的值为future only时,表示在此之前该数据类型关联的列不继承该默认值对象的值。
例:
sp_bind efault ‘cou sr_x f’,’course.xf’
3、删除默认值对象
如果要删除一个默认值对象,首先应解除默认值对象与用户定义类型及表字段的绑定关系,然后才能删除该默认值对象。
(1)利用sp_unbindef ault解除绑定关系
语法格式如下:
sp_unbi ndefau lt [@objname=]’被绑定对象名’
[,[@futureo nly=]’futureo nly_fl ag’]
drop table if exists admin(2)删除默认值对象
解除默认值对象与用户定义类型及表字段的绑定关系后,即可用DROP语句删除默认值对象。
语法格式如下:
DROP DEFAULT默认值对象名
三、规则对象的定义、使用与删除
规则对象的使用方法与默认值对象的使用步骤类似:
(1)定义规则对象
(2)将规则对象绑定到列或用户自定义类型
规则对象的定义可利用企业管理器定义,也可利用SQL语句定义。
1、利用企业管理器定义规则对象并绑定到自定义类型或列
2、利用SQL语句定义规则对象并绑定到自定义类型或列
(1)定义规则对象,语法格式如下:
CREATERULE 规则名 AS 条件表达式
其中:条件表达式不能包含列或其他数据库对象,可以包含不引用数据库对象的内置函数,在条件表达中包含一个局部变量,局部变量的前面都有一个@符号,使用UPDAT E或INSE RT语句修改或插入值时,该表达式用于对规则关联的列值进行约束,创建规则时,局
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论