欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > DOCX文档下载  

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

    • 资源ID:3166198       资源大小:39.17KB        全文页数:7页
    • 资源格式: DOCX        下载积分:6.99金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要6.99金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

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

    SQL用户自定义的数据类型规则默认用户自定义的数据类型、默认值、规则 一、用户自定义的数据类型 用户自定义数据类型可看做是系统数据类型的别名。 在多表操作的情况下,当多个表中的列要存储相同类型的数据时,往往要确保这些列具有完全相同的数据类型、长度和为空性。例如,对于student数据库中表student、grade和course三张表的xh,kh两个列必须具有相同的数据类型。 创建用户自定义数据类型时首先应考虑如下三个属性: 数据类型名称 新数据类型所依据的系统数据类型 为空性 如果为空性未明确定义,系统将依据数据库或连接的ANSI NULL默认设置进行指派。 1、创建用户自定义数据类型的方法如下: 利用企业管理器定义 利用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、删除用户自定义数据类型 利用企业管理器 利用SQL语句 语法格式如下: sp_droptype typename= type 其中type为用户自定义数据类型的名称,应用单引号括起来。 例:删除student_xh用户自定义数据类型 sp_droptype student_xh 说明: 如果在表定义内使用某个用户定义的数据类型,或者将某个规则或默认值绑定到这种数据类型,则不能删除该类型。 要删除一用户自定义类型,该数据类型必须存在,否则返回一条错误信息。 3、执行权限 执行权限默认授予sysadmin固定服务器角色、db_ddladmin和db_owner固定数据库角色成员以及数据类型所有者。 4、利用自定义数据类型定义字段 用户自定义数据类型与基类型一样使用,可定义为字段的数据类型。 二、默认值对象的定义、使用与删除 默认值对象的定义、使用与删除既可利用企业管理器实现,也可利用SQL语句实现。 1、通过企业管理器定义和绑定DEFAULT默认值对象 2、通过SQL语句定义和绑定DEFAULT默认值对象 通过SQL语句定义DEFAULT默认值对象 命令格式如下: CREATE DEFAULT 默认值名称 AS 常量表达式 常量表达式可以含有常量、内置函数、字符和日期常量用单引号引起来;货币、整数和浮点常量不需要使用引号。十六进制数据必须以0x开头,货币数据必须以美元符号开头。默认值对象必须与列数据类型兼容。 例:定义学分默认值 CREATE DEFAULT COURSE_XF AS 0 通过系统存储过程绑定DEFAULT默认值对象 创建默认值对象后,要使其作用,应使用sp_bindefault存储过程将其绑定到列或用户自定义数据类型。 语法格式如下: sp_bindefault defname=默认值对象名, objname=被绑定对象的名称 ,futureonly=futureonly_flag 其中参数futureonly_flag仅在将默认值对象绑定到用户定义数据类型时才使用,当futureonly_flag的值为futureonly时,表示在此之前该数据类型关联的列不继承该默认值对象的值。 例: sp_bindefault cousr_xf,course.xf 3、删除默认值对象 如果要删除一个默认值对象,首先应解除默认值对象与用户定义类型及表字段的绑定关系,然后才能删除该默认值对象。 利用sp_unbindefault解除绑定关系 语法格式如下: sp_unbindefault objname=被绑定对象名 ,futureonly=futureonly_flag 删除默认值对象 解除默认值对象与用户定义类型及表字段的绑定关系后,即可用DROP语句删除默认值对象。 语法格式如下: DROP DEFAULT 默认值对象名 三、规则对象的定义、使用与删除 规则对象的使用方法与默认值对象的使用步骤类似: 定义规则对象 将规则对象绑定到列或用户自定义类型 规则对象的定义可利用企业管理器定义,也可利用SQL语句定义。 1、利用企业管理器定义规则对象并绑定到自定义类型或列 2、利用SQL语句定义规则对象并绑定到自定义类型或列 定义规则对象,语法格式如下: CREATE RULE 规则名 AS 条件表达式 其中:条件表达式不能包含列或其他数据库对象,可以包含不引用数据库对象的内置函数,在条件表达中包含一个局部变量,局部变量的前面都有一个符号,使用UPDATE或INSERT语句修改或插入值时,该表达式用于对规则关联的列值进行约束,创建规则时,局部变量代表了UPDATE或INSERT语句输入的值。 另外有如下几点说明: 创建的规则对先前已存在于数据库中的数据无效。 单个批处理中,CREATE RULE语句不能与其他T-SQL语句组合使用。 规则表达式的类型必须与列的数据类型兼容,不能将规则绑定到text、image、或timestamp列。要用单引号将字符和日期常量引起来,在十六进制常量前加0x。 对于用户定义数据类型,当在该类型的数据列中插入值,或更新该类型的数据列时,绑定到该类型的规则才会激活。规则不检查变量,所以在向用户定义数据类型的变量赋值时,不能与列绑定的规则冲突。 如果列同时有默认值和规则与之关联,则默认值必须满足规则的定义,与规则冲突的默认值不能插入到列。 3、将规则对象绑定到自定义类型或列 语法格式如下: sp_bindrule rulename= 规则对象名 objname=被绑定的对象名 ,futureonly= futureonly_flag 其中:“被绑定对象名”为绑定到规则的列或用户定义数据类型,如果采用“表.字段名”格式,则认为绑定到表的列,否则绑定到用户定义数据类型;参数futureonly_flag仅当将规则绑定到用户定义数据类型时才使用,如果futureonly_flag设置为futureonly,用户定义数据类型的现有列不继承新规则。如果futureonly_flag为NULL,当被绑定的数据类型当前无规则时,新规则将绑定到用户定义数据类型的每一列。 例:创建课程的规则,并绑定到KH字段。 CREATE RULE KH_RULE AS range like K0-90-9 Sp_bindrule kh_rule,course.kh 例:创建“课程号”用户定义数据类型,并规则kh_rule绑定到用户定义类型上。 Sp_addtype course_kh,char(3),not null Sp_bindrule kh_rule,course_kh 4、规则对象的删除 删除规则对象前,首先应使用系统存储过程sp_unbindrule解除被绑定对象与规则对象之间的绑定关系。格式如下: sp_unbindrule objname= 被绑定对象名 ,futureonly= futureonly_flag 其中:参数futureonly_flag仅用于解除用户定义数据类型规则的绑定,如果futureonly_flag设置为futureonly,规则仍然对现有的属于该数据类型的列有效。 在解除列或自定义数据类型与规则对象之间的绑定关系后,就可以删除规则对象了。 删除规则对象的SQL语句的语法格式如下: DROP RULE 规则对象名 例:解除课程号列与kh_rule之间的绑定关系,并删除规则对象kh_rule。 USE STUDENT IF EXISTS(SELECT NAME FROM sysobjects WHERE name=kh_ruleAND type=R) BEGIN EXEC sp_unbindrule course.kh DROP RULE kh_rule END GO

    注意事项

    本文(SQL用户自定义的数据类型规则默认.docx)为本站会员(牧羊曲112)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开