SQL用户自定义的数据类型、规则、默认.doc

SQL用户自定义的数据类型、规则、默认.doc

ID:50993351

大小:41.02 KB

页数:8页

时间:2020-03-08

SQL用户自定义的数据类型、规则、默认.doc_第1页
SQL用户自定义的数据类型、规则、默认.doc_第2页
SQL用户自定义的数据类型、规则、默认.doc_第3页
SQL用户自定义的数据类型、规则、默认.doc_第4页
SQL用户自定义的数据类型、规则、默认.doc_第5页
资源描述:

《SQL用户自定义的数据类型、规则、默认.doc》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、用户自定义的数据类型、默认值、规则一、用户自定义的数据类型用户自定义数据类型可看做是系统数据类型的别名。在多表操作的情况下,当多个表中的列要存储相同类型的数据时,往往要确保这些列具有完全相同的数据类型、长度和为空性(数据类型是否允许为空)。例如,对于student数据库中表student、grade和course三张表的xh,kh两个列必须具有相同的数据类型。创建用户自定义数据类型时首先应考虑如下三个属性:(1)数据类型名称(2)新数据类型所依据的系统数据类型(又称为基类型)(3)为空性如果为空性未明

2、确定义,系统将依据数据库或连接的ANSINULL默认设置进行指派。1、创建用户自定义数据类型的方法如下:(1)利用企业管理器定义(2)利用SQL命令定义数据类型在SQLServer中,通过系统存储过程实现用户数据类型的定义。语法格式如下:sp_addtype[@typename=]type,/*自定义类型名称*/[@phystype=]system_data_type/*基类型*/[,[@nulltype=]null_type/*为空性*/[,[@owner=]owner_name]/*创建者或所有者

3、*/其中:type:用户自定义数据类型的名称。System_data_type:用户自定义数据类型所依据的基类型。如果参数中嵌入有空格或标点符号,则必须用引号将该参数引起来。null_type:指明用户自定义数据类型处理空值的方式。取值可为’NULL’、’NOTNULL’、’NONULL’三者之一(注意:必须用单引号引起来)。如果没有用sp_addtype显式定义null_type,则将其设置为当前默认值,系统默认值一般为’NULL’。例:定义学号字段的数据类型sp_addtype’student_x

4、h’,’char(4)’,’notnull’2、删除用户自定义数据类型(1)利用企业管理器(2)利用SQL语句语法格式如下:sp_droptype[@typename=]type其中type为用户自定义数据类型的名称,应用单引号括起来。例:删除student_xh用户自定义数据类型sp_droptype’student_xh’说明:(1)如果在表定义内使用某个用户定义的数据类型,或者将某个规则或默认值绑定到这种数据类型,则不能删除该类型。(2)要删除一用户自定义类型,该数据类型必须存在,否则返回一条错

5、误信息。3、执行权限执行权限默认授予sysadmin固定服务器角色、db_ddladmin和db_owner固定数据库角色成员以及数据类型所有者。4、利用自定义数据类型定义字段用户自定义数据类型与基类型一样使用,可定义为字段的数据类型。二、默认值对象的定义、使用与删除默认值对象的定义、使用与删除既可利用企业管理器实现,也可利用SQL语句实现。1、通过企业管理器定义和绑定DEFAULT默认值对象2、通过SQL语句定义和绑定DEFAULT默认值对象(1)通过SQL语句定义DEFAULT默认值对象命令格式如

6、下:CREATEDEFAULT默认值名称AS常量表达式常量表达式可以含有常量、内置函数、字符和日期常量用单引号引起来;货币、整数和浮点常量不需要使用引号。十六进制数据必须以0x开头,货币数据必须以美元符号($)开头。默认值对象必须与列数据类型兼容。例:定义学分默认值CREATEDEFAULTCOURSE_XFAS0(2)通过系统存储过程绑定DEFAULT默认值对象创建默认值对象后,要使其作用,应使用sp_bindefault存储过程将其绑定到列或用户自定义数据类型。语法格式如下:sp_bindefau

7、lt[@defname=]’默认值对象名’,[@objname=]’被绑定对象的名称’[,[@futureonly=]’futureonly_flag’]其中参数futureonly_flag仅在将默认值对象绑定到用户定义数据类型时才使用,当futureonly_flag的值为futureonly时,表示在此之前该数据类型关联的列不继承该默认值对象的值。例:sp_bindefault‘cousr_xf’,’course.xf’3、删除默认值对象如果要删除一个默认值对象,首先应解除默认值对象与用户定义类

8、型及表字段的绑定关系,然后才能删除该默认值对象。(1)利用sp_unbindefault解除绑定关系语法格式如下:sp_unbindefault[@objname=]’被绑定对象名’[,[@futureonly=]’futureonly_flag’](2)删除默认值对象解除默认值对象与用户定义类型及表字段的绑定关系后,即可用DROP语句删除默认值对象。语法格式如下:DROPDEFAULT默认值对象名三、规则对象的定义、使用与删除规则对象的使用方法与默认值

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。