- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
An Introduction to Database System 第五章 数据库完整性 约束 check约束 check 约束(续) default约束、删除约束 规则 规则(续) 默认值 完整性的违约处理 参照完整性的违约处理 触发器 触发器(续) 触发器执行顺序 触发器的递归触发 这个功能怎么实现? deleted表和inserted表 deleted表和inserted表示例 转系历史数据的跟踪存储 问题的解决办法 实现CS_S视图的数据插入 实现Course表的违约处理 实现Course表的违约处理(续) 触发器小结 * 数据库的安全性是尽可能保证非法用户不破坏数据的正确性。 数据库的完整性是尽可能保证合法用户不破坏数据的正确性。 数据库的完整性是为了尽可能防止数据库中存在不符合语义的数据。 问题:你还记得实体完整性约束和参照完整性约束是怎么回事吗? 为此,DBMS需要完成: 提供定义完整性约束条件的机制 提供完整性检查的方法 违约处理 完整性分类:实体完整性、参照完整性和用户定义完整性。 约束:就是一种强制性的规定。 1、建立非空约束。 alter table course alter column credit smallint not null 其中,必须给出列的类型。 SQL Server的六种约束: not null 非空约束 check 检查约束 unique 唯一约束 primary key 主码约束 foreign key 外码约束 default 默认约束 约束的建立: 在创建表的同时建立 在已有表上建立 注意:若表中已有数据,则建立约束时可能会失败。 2、建立唯一约束。 alter table course add constraint UQ_cname unique(cname) 其中:constraint关键词即对该约束进行命 名,即UQ_cname是约束名。 注意:对每个约束都进行命名是个好习惯 注意:非空约束不能命名。删除某列的非空约束语句为: alter table course alter column credit smallint null 1、创建表时建立check约束。 create table stu ( sno char(9) constraint PK_stu primary key, name char(8) not null, age smallint constraint c_age check(age 0 and age 100) ) 逻辑表达式 问题:此时age列值可以是空吗? 或 create table stu ( sno char(9), name char(8) not null, age smallint, constraint PK_stu primary key (sno), constraint c_age check (age 0 and age 100) ) 2、在表中增加check约束 alter table student add constraint c_age check(Sage 0 and Sage 100) check约束可用于建立表中属性取值上的某些约束关系。 答:可以是空。 3、规定性别的取值只能是男或女。 4、check的表达式可以包含多个属性。如规定CS系学生必须 25岁以下。 问题:此时ssex列值可空吗? alter table student add constraint c_ssex check(ssex in (男, 女)) 答:可以是空。问题:若要求该列取值同时不可为空,则如何表达? alter table student add constraint c_cs_age check(sdept cs or sage = 25) 问题:你知道这个约束条件是怎么得到的吗? alter table student add constraint c_ssex check(ssex in (男, 女) and ssex is not null) default约束:可以对列设置默认值。如对性别列默认取值为男。 1、创建表时建立default约束。 create table student ( sno char(9) primary key, ssex char(2)
您可能关注的文档
最近下载
- DLT 499-2024 低压电力技术规程.doc VIP
- 《土壤污染与修复》课件.ppt VIP
- 2024年内蒙古自治区通辽市科尔沁区建国街道招聘社区工作者真题及答案详解一套.docx VIP
- 2025-2026学年小学心理健康一年级苏科版(2016)教学设计合集.docx
- 道德与法治六年级上册全册课件.ppt VIP
- 智能制造系统集成应用(高级).pptx VIP
- 银行业金融机构安全评估标准.pdf VIP
- 泛微协同办公平台e-office10用户使用手册.docx VIP
- 基于51单片机的智能小车开题报告-.ppt VIP
- 青岛版新版六年级上册科学每单元+期中+期末的测试题.docx VIP
文档评论(0)