数据库系统中的数据完整性

数据库系统中的数据完整性摘要:数据库的数据完整性是设计数据库的核心内容,一个数据库的完整性约束设计的好坏,将直接影响到这个数据库的性能,同时也会影响到整个数据库的开发,因此一个好的数据库需要严格考虑其完整性约束。该文主要结合学生成绩管理系统,介绍了在SQLServer2005数据库应用系统中,实现数据完整性的设计方法。关键词:数据库;数据完整性;约束中图分类号:TP311文献标识码:A文章编号:1009-3044(2011)16-3770-02SQLServer2005是微软公司具有里程碑意义的企业级数据库产品。既是安全、可靠、高效的企业级数据管理平台又是先进、一体化的商业智能平台以及极具扩展性和灵活性的开发平台。本文以学生成绩管理系统为例,来介绍数据库系统中数据的完整性。数据的完整性是指数据的精确性和可靠性,主要用于保证数据库中数据的质量。可以从两个方面来理解数据的完整性:(1)数据的准确性,即每个字段的取值必须满足一定的数据类型、取值范围和约束等;(2)数据的一致性,即相关表格各字段的取值必须互相匹配。在数据库应用系统中,保证数据的完整性是设计数据库的最基本的要求;数据完整性设计的好坏,直接关系到数据库系统的正确性、一致性和可靠性,甚至关系到整个数据库系统的成败。当我们在数据库系统中使用INSERT、DELETE和UPDATE语句修改数据库时,数据的完整性就有可能遭到人为的破坏。为了保证数据的正确性,为了保护数据库内容的一致性,可以通过SQLServer对数据库添加一个或多个数据完整性约束。这些约束即可以限制数据库中字段的取值,也可以保护数据库中特定的数据不被任意删除。在SQLServer数据库系统中,数据的完整性主要有以下3类:1)实体完整性;即保证表中的每一行数据在该表中是唯一的。为了保证实体完整性,必须指定表中的一个字段或多个字段的组合作为它的主键(primarykey)。一个表只能含有一个主键,而且主键的值不能为空,不可重复。2)域完整性:是指数据库表中的字段必须满足某种特定的数据类型或约束,数据类型是指某个字段的取值必须满足一定的数据格式,例如,日期字段必须是datetime或smalldatetime,约束可以包括限制类型、限制格式或限制可能值的范围等。3)参照完整性:是指在数据库表中输入或删除记录时,包含主关键字(primarykey)的主表和包含外关键字(foreignkey)的从表的数据必须对应一致,保证了表之间数据的一致性。防止数据的丢失或无意义的数据在数据库中扩散。在SQLServer2005中可以通过两种方法来实现数据完整性:定义表格的完整性约束以使用索引和触发器。1定义表格的完整性约束该方法是在sql语句中,通过添加约束来实现数据的完整性。主要约束有:非空(notnull)约束、默认值(default)约束、唯一(unique)约束、主键(primarykey)约束、外键(foreignkey)约束、检查(check)约束、默认值(default)、规则(rule)等。这种方法的主要特点是定义简单、安全可靠、维护方便。1)非空约束(notnull)是指某个字段的取值在没有指定默认值的情况下不能为空;默认值(default)约束是指当用INSERT语句向数据库表中插入数据时,如果没有为某一个字段指定数据,SQLServer会自动输入预定值,每个字段只能有一个默认值约束;检查约束(check)是用来验证字段输入内容的规则,是指某一个字段必须满足检查约束的条件,若不满足,数据就无法正常输入,可以对表中的每个字段设置检查约束。例如,在学生成绩管理系统中,创建学生信息表时,限定学号Sno、姓名Sname、性别Ssex出生日期Sbirthdate、籍贯Sborn等列值不允许为空;性别Ssex的检查约束为“男”或“女”。Createtablestudent(Snointnotnull,Snamechar(10)notnull,Ssexchar(2)check(Ssex=‘男’orSsex=’女’)notnull,Sbirthdatesmalldatetimenotnull,Sbornchar(50)notnull)执行sql语句后,当向学生表student里录入数据时,上述字段必须有内容,不能为空,性别Ssex字段只能接受“男”或“女”两个取值,否则数据不能成功插入到数据库中。2)主键约束(primarykey)和唯一约束(unique),二者都是指某个字段或某几个字段组合取值的唯一性,防止在该字段或字段的组合中出现重复的值。一个表中,可以包含多...

1、当您付费下载文档后,您只拥有了使用权限,并不意味着购买了版权,文档只能用于自身使用,不得用于其他商业用途(如 [转卖]进行直接盈利或[编辑后售卖]进行间接盈利)。
2、本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供参考,付费前请自行鉴别。
3、如文档内容存在侵犯商业秘密、侵犯著作权等,请点击“举报”。

常见问题具体如下:

1、问:已经付过费的文档可以多次下载吗?

      答:可以。登陆您已经付过费的账号,付过费的文档可以免费进行多次下载。

2、问:已经付过费的文档不知下载到什么地方去了?

     答:电脑端-浏览器下载列表里可以找到;手机端-文件管理或下载里可以找到。

            如以上两种方式都没有找到,请提供您的交易单号或截图及接收文档的邮箱等有效信息,发送到客服邮箱,客服经核实后,会将您已经付过费的文档即时发到您邮箱。

注:微信交易号是以“420000”开头的28位数字;

       支付宝交易号是以“2024XXXX”交易日期开头的28位数字。

客服邮箱:

biganzikefu@outlook.com

所有的文档都被视为“模板”,用于写作参考,下载前须认真查看,确认无误后再购买;

文档大部份都是可以预览的,笔杆子文库无法对文档的真实性、完整性、准确性以及专业性等问题提供审核和保证,请慎重购买;

文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为依据;

如果您还有什么不清楚的或需要我们协助,可以联系客服邮箱:

biganzikefu@outlook.com

常见问题具体如下:

1、问:已经付过费的文档可以多次下载吗?

      答:可以。登陆您已经付过费的账号,付过费的文档可以免费进行多次下载。

2、问:已经付过费的文档不知下载到什么地方去了?

     答:电脑端-浏览器下载列表里可以找到;手机端-文件管理或下载里可以找到。

            如以上两种方式都没有找到,请提供您的交易单号或截图及接收文档的邮箱等有效信息,发送到客服邮箱,客服经核实后,会将您已经付过费的文档即时发到您邮箱。

注:微信交易号是以“420000”开头的28位数字;

       支付宝交易号是以“2024XXXX”交易日期开头的28位数字。

文秘专家
机构认证
内容提供者

1

确认删除?