- 1、本文档共51页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第3章 表的创建与维护
参照完整性 6530004 约束方法:外键约束 课程编号 学号 班级人数 … 3000188 30002null 3000378 30001 310310001 78 310310 诸葛亮310310 刘备310220 蔡文姬310220 司马懿310220 曹操…. 班级编号 姓名 学号 × 场景: 学校在进行每学期的奖学金评选的时候,要求学生通过校内网站提交奖学金申请表,这个表中数据将会加入到学生数据库中,作为评选依据。 学校的学籍管理办公室数据库管理员抱怨,每次都有学生输入了错误的数据,如:错误的专业名称、和学籍档案不一致的姓名、错误的导师名称等等,有时也会因网络超时,相同的信息重复的输入多次,这样会增加了更多的管理工作。 若你是学校的数据库管理人员认为可由什么方法解决这个问题,提高效率呢? 通过实现约束来解决这个问题。 约束是SQL Server提供的自动保持数据库完整性的一种方法,它通过限制字段中数据、记录中数据和表之间的数据来保证数据的完整性。 在SQL SERVER中,对于基本表的约束分为列约束和表约束。 列约束是对某一个特定列的约束,包含在列定义中,直接跟在该列的其他定义之后,用空格分隔,不必指定列名;表约束与列定义相互独立,不包括在列定义中,通常用于对多个列一起进行约束,与列定义用“,”分隔,定义表约束时必须指出要约束的那些列的名称。 完整性约束的基本语法格式为: [CONSTRAINT constraint_name(约束名)] 约束类型 约束不指定名称时,系统会给定一个名称。 在SQL Server 2005中有6种约束:主键约束(primary key constraint)、惟一性约束(unique constraint)、检查约束(check constraint)、默认约束(default constraint)、外部键约束(foreign key constraint)和空值(NULL)约束。 PRIMARY KEY 约束: PRIMARY KEY 约束用于定义基本表的主键,它是惟一确定表中每一条记录的标识符,其值不能为NULL,也不能重复,以此来保证实体的完整性。 PRIMARY KEY 与 UNIQUE 约束类似,通过建立唯一索引来保证基本表在主键列取值的唯一性,但它们之间存在着很大的区别: ①一个表只能有一个 PRIMARY KEY 约束 ,但可定义多个UNIQUE约束; ②对于指定为PRIMARY KEY的一个列或多个列的组合,其中任何一个列都不能出现空值,而对于UNIQUE所约束的唯一键,则允许为空。 注意:不能为同一个列或一组列既定义UNIQUE约束,又定义PRIMARY KEY约束; PRIMARY KEY既可用于列约束,也可用于表约束。 主键的创建操作方法有两种:SQL Server管理平台操作法和Transact-SQL 语句操作法。 (1) SQL Server管理平台操作法(如图示) (2)使用Transact-SQL语句操作法设置主键约束,其语法形式如下: PRIMARY KEY CONSTRAINT constraint_name PRIMARY KEY ( column_name ) (2)举例: 建立一个SC表,包括:SNO、CNO和GRADE,定义SNO,CNO共同组成SC的主键。 程序清单如下: CREATE TABLE SC (SNO CHAR(5) NOT NULL, CNO CHAR(5) NOT NULL, GRADE NUMERIC(3), CONSTRAINT SC_PRIM PRIMARY KEY (SNO,CNO)) UNIQUE约束: 惟一性约束用于指定一个或者多个列的组合值具有惟一性,以防止在列中输入重复的值。定义了UNIQUE约束的那些列称为唯一键,系统自动为唯一键建立唯一索引,从而保证了唯一键的唯一性。 当使用惟一性约束时,需要考虑以下几个因素: 使用惟一性约束的字段允许为空值; 一个表中可以允许有多个惟一性约束; 可以把惟一性约束定义在多个字段上; 惟一性约束用于强制在指定字段上创建一个惟一性索引; 默认情况下,创建的索引类型为非聚集索引。 创
文档评论(0)