数据库关系完整性约束

数据库关系完整性约束

完整性约束

  • 实体完整性约束(主键约束): 不空值、不重复、复合键包含主键,则其中的键都不能为空

  • 参照完整性约束(外键约束)

    • 删除规则:被引用则不能被删除

      如果一个实体E被另一个实体F引用,可以禁止删除该实体E。

      例如,某所学校录取了1000名学生,则不能将该学校删除;如果要删除该学校,则必须同时把隶属于该学校的1000名学生的信息也删除。(被参照实体 后删除)

    • 插入规则:

      如果一个实体F引用了另一个实体E,那么实体E必须存在数据库中。

      例如,某位学生被某所学校录取,那么该学校必须已经存在学校实体集中;否则,需要先将学校实体集中的信息存到数据库后,才能将该学生的信息插入到数据库中。(被参照实体 先插入)

  • 用户定义完整性约束

    • 用户定义完整性约束则是用户根据具体的数据库应用场景,设置的具体的约束条件,用户定义完整性约束可以反映数据的特殊语义要求。
    • 例如,在Student关系中,假设学校在录取学生的时候明确表明每位学生都必要有姓名和年龄信息,则Student关系中的Sname和Sage属性均不能取空值。

其它约束

  • 非空约束 not null
  • 唯一约束 unique
  • 自增长约束 auto_increment
  • 默认值约束 default
  • 检查约束 check
  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值