数据库表怎么添加约束条件

数据库表怎么添加约束条件,第1张

第一步:新建数据库并设置可写权限

打开SQL Server管理器窗口,用本地用户登录;然后点击右键——新建数据库;完成之后将数据库文件及日志文件设置为可读可写,如图:

请点击输入图片描述

请点击输入图片描述

请点击输入图片描述

第二步:新建数据表

展开数据库,点击表——新建表,输入名称及数据类型,如图:

(注:数据类型非常重要)

请点击输入图片描述

请点击输入图片描述

第三步:设置主键约束

点击表右键——设计——选中id——右键——设置主键,将id设置为主键,主键默认唯一。

如图:

请点击输入图片描述

请点击输入图片描述

请点击输入图片描述

第四步:测试主键约束

在数据表中输入数据,为测试主键的约束,输入两行一模一样的id,保存;

如图所示,保存会提示主键不允许重复。

请点击输入图片描述

请点击输入图片描述

第五步:设置非主键唯一值约束

选中表,点击菜单栏——新建查询,将IDcard设为非主键唯一值,输入以下代码:

ALTER TABLE Users

ADD unique(IDcard),然后点击执行。

如图:

请点击输入图片描述

请点击输入图片描述

第六步:测试非主唯一约束

同理,在数据表中输入两行id不同,IDCard相同的数据,并保存;若出现错误提示,将IDCard修改之后再检测,如图:

请点击输入图片描述

请点击输入图片描述

第七步:关闭数据库并断开连接

由于数据库会在后台运行,所以测试完之后,本地数据库一定要断开连接,然后关闭,如图:

请点击输入图片描述

数据库完整性(database

integrity)是指数据库中数据的正确性和相容性,其目的是防止垃圾数据的进出。数据库完整性由各种各样的完整性约束来保证,因此可以说数据库完整性设计就是数据库完整性约束的设计。加在数据库之上的语义约束条件就是数据库完整性约束条件。

完整性约束条件作用对象可以使关系、元组、列三种。

列约束主要是列的数据类型、取值范围、精度、排序等约束条件。

元组的约束是元组中各个字段间的联系的约束。

关系的约束是若干元组间、关系集合上以及关系之间的联系的约束。

完整性约束条件涉及这三类对象,其状态可以是静态的,也可以是动态的。所谓静态约束是指数据库每一确定状态时的数据对象所应满足的约束条件。它是反映数据库状态合理性的约束,这是最重要的一类完整性约束。

动态约束是指数据库从一种状态转变为另一种状态时,新、旧值之间所应满足的约束条件。

完整性约束条件可分为以下六类:

静态列级约束

静态元组约束

静态关系约束

动态列级约束

动态元组约束

动态关系约束

1.

静态列级约束是对一个列的取值域的说明,包括以下几个方面:

(1)

对数据类型的约束,包括数据的类型、长度、单位、精度等;

(2)

对数据格式的约束。例如规定日期的格式为yyyy-mm-dd;

(3)

对取值范围或取值集合的约束。例如规定学生的成绩取值范围为0~100;

(4)

对空值的约束,规定哪些列可以为空值,哪些列不能为空值;

2.

静态元组约束就是规定元组的各个列之间的约束关系。例如,订货关系中包含发货量、订货量等列,规定发货量不得超过订货量。

3.

静态关系约束是指在一个关系的各个元组之间或者若干关系之间存在的约束。常见的静态约束有:

(1)

实体完整性约束;

(2)

引用完整性约束;

(3)

函数依赖约束;大部分函数依赖约束都在关系模式中定义。

(4)

统计约束;即字段值与关系中多个元组的统计值之间的约束关系。例如,规定部门经理的工资不得高于本部门职工平均工资的5倍,不得低于本部门职工平均工资的2倍。

4.

动态列级约束是修改列定义或列值时应满足的约束条件,包括下面两方面:

(1)

修改列定义时的约束。例如,将允许空值的列改为不允许空值时,如果该列目前已存在空值,则拒绝这种修改。

(2)

修改列值时的约束。修改列值时有时需要参照其旧值,并且新旧值之间需要满足某种约束条件。例如,职工调整后的工资不得低于其调整前的原来工资;职工婚姻状态的变化只能是由未婚到已婚、已婚到离异、离异到再婚等几种情况。

5.

动态元组约束是指修改元组的值时元组中各个字段间需要满足某种约束条件。例如,职工工资调整时新工资不得低于原工资+工龄*1.5等。

6.

动态关系约束是加在关系变化前后状态上的限制条件。例如,在集成电路芯片设计数据库中,一个设计中用到的所有单元的工艺必相同,因此,在更新某个设计单元时,设计单元的新老工艺必须保持一致。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/6807444.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-28
下一篇 2023-03-28

发表评论

登录后才能评论

评论列表(0条)

保存