数据库设计第3章.ppt

  1. 1、本文档共70页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据库设计第3章

* 2、定义主键和实体完整性 使用PRIMARY KEY子句来实现实体完整性。 例如: CONSTRAINT pk PRIMARY KEY (catalogNo) CONSTRAINT pk1 PRIMARY KEY (catalogNo, actorNo) 3、定义外键和参照完整性 使用FOREIGN KEY子句在表中定义外键。 SQL通过限制子表的INSERT和UPDATE操作实现参照完整性,这些操作试图在子表中创建和父表中的候选键不相匹配的外键值。 注:意思就是,父表子表中都有这个列,你修改了子表中的这个列,那么父表中的相应列无法得到同步的更新,会造成数据的不同步。 * 如果是更新或删除父表中的和子表有匹配行的候选键值的UPDATE和DELETE操作,那么SQL通过在FOREIGN KEY子句中使用ON UPDATE和ON DELETE子操作来实现引用操作。 注:意思就是,父表子表中都有这个列,你修改父表列时,可以引入FOREIGN KEY (a)ON UPDATE {CASCADE} 来表示当父表该列修改时,会触发子表同列的修改。 FOREIGN KEY (a) ON DELETE {CASCADE} 就表示当父表该列删除时,会触发子表同列的删除操作。 主键外键的定义都是在创建表时直接定义好的,作为列的性质,可使用ALTER TABLE 修改表结构。 * 使用ON UPDATE和ON DELETE子操作实现引用操作: CASCADE – 当从父表更新或删除行时,对子表中匹配的行也要作相应的更新或删除。 SET NULL – 当从父表更新或删除行时,将子表中匹配的外键值置为null。 SET DEFAULT -当从父表更新或删除行时,将子表中匹配的外键值置为一个指定的默认值。 NO ACTION –当从父表更新或删除行时,子表中匹配的外键不进行任何操作。 * 例子: CREATE TABLE TABLE_A { a VARCHAR(32) NOT NULL CONSTRAINT pk PRIMARY KEY , b VARCHAR(32) NOT NULL CONSTRAINT fk FOREIGN KEY (b) REFERENCES TABLE_B (b) ON UPDATE CASCADE, c CHAR(4) DEFAULT 0, d DECIMAL(20, 6), e INTEGER }; * 例中各项的意思 建一个表,a列为32位长字符串类型,不能为空,是主键; b列为32位长字符串类型,不能为空,是外键,且当其被修改时,子表(TABLE_B)中的b列也同时被修改; c列是4位字符串类型,默认为0; d列为浮点类型,存储20位整数部分和6位小数位; e列位数字类型。 ON UPDATE和ON DELETE,实际中应用也不多,在业务应用当中,作为子表主键的父表的列值,通常设计为不可修改的,而需要修改时,多数是通过关联方式一并修改,或者通过存储过程进行修改。 * 利用视图定义CREATE VIEW语句 CREATE VIEW ViewName [(newColumnName [,...]] AS Subselect 例子:CREATE VIEW StaffBranch1 AS SELECT staffNo, name, position FROM Staff WHERE branchNo = ‘B001’; * 三十五、Query-By-Example (QBE) QBE是一种以图形为基础的点对点“point-and-click” 数据库查询方法。 是一种对于非技术用户(就是只关心数据本身的用户)查询数据库的方法。 使用模板为查询数据提供了一种可视化工具,查询数据库通过解释要回答的查询得到。 Chapter Name September 98 * Chapter Name September 98 * Chapter Name September 98 * Chapter Name September 98 * Chapter Name September 98 * Chapter Name September 98 * Chapter Name September 98 * Chapter Name September 98 * Chapter Name September 98 * Chapter Name September 98 * Chapter Name September 98 * Chapter Name September 98 * Chapter Name

文档评论(0)

shuwkb + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档