SQL基本表的创建中是通过什么实现参照完整性规则的?

 我来答
匿名用户
2013-01-16
展开全部
主键实现 唯一
外键实现 完整

例如有 学校表 班级表 学生表

班级表里面有 所属学校, 并创建了外键约束
学生表里面有 所属班级, 并创建了外键约束

这样创建完毕以后,

例如我插入了下面这样的数据.

学校: 某某大学
班级: 2012级1班; 2012级2班; 2012级3班;
学生: 张三(1班); 李四(2班);王五(3班)

数据创建好以后。
如果没有外键的话

我删除 学校 某某大学
那么 班级里面的数据就有问题了。
去查询一下 班级的所属学校, 是有数据的, 但是去查询学校, 发现学校不存在了。

我删除 2012级3班;
那么 王五 的数据就有问题了。
去查询一下, 显示 王五所在班级为 3班, 但是班级表里面没这个记录。

这样就导致数据不完整了。

如果有外键约束的话。
我删除 学校 某某大学
默认情况下, 数据库就会拒绝我的本次操作, 并提示我有外键的数据存在, 不能删除

我删除 2012级3班。
默认情况下, 数据库就会拒绝我的本次操作, 并提示我有外键的数据存在, 不能删除

我需要把 王五所在班级 从3班 修改为 2班 以后,
确保 2012级3班 下面没有学生了, 我才能删除 2012级3班
光点科技
2023-08-15 广告
通常情况下,我们会按照结构模型把系统产生的数据分为三种类型:结构化数据、半结构化数据和非结构化数据。结构化数据,即行数据,是存储在数据库里,可以用二维表结构来逻辑表达实现的数据。最常见的就是数字数据和文本数据,它们可以某种标准格式存在于文件... 点击进入详情页
本回答由光点科技提供
heshengxi10
推荐于2017-10-03
知道答主
回答量:46
采纳率:0%
帮助的人:21.5万
展开全部
参照完整性规则有以下几种方式:
1. 数据库 外键
2. 数据库 触发器
3. 数据库 存储过程或函数类
4. 程序实现完整性
建议使用 2,3,
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式