(二)表的连接与外键约束

外键约束和表连接

【建立表的关系】
1.额外建立一张表描述两个表之间的关系,存储两张需要连接的表的主键对应关系。
2.利用外键约束
外键:一张表的某个字段引用着另一张表的主键,在数据多的表中多一个字段,存储对应的另一张表的主键。

外键的创建:
CONSTRAINT <外键名前缀> FOREIGN KEY <表中的键名> REFERENCES <引用的表名> (<引用的字段>);

级联:
删除了一部分,有对应关系的另一个部分会被删除。

【表连接】
假如有t_student 和 t_class两个表,其中t_student中存着学生的姓名和所属班级,t_class中存着班级名称A、B、C,通过外键建立了二者联系后,如果要找出所有A班的人,需要先在t_class中找到班级的主键,然后再去t_student中查找所有符合这个主键的外键值。最简单的方法是使用嵌套查询。
SELECT * FROM t_student WHERE class = (SELECT id FROM t_class WHERE name = ‘A’);

2.同时查询两张表,会对表进行笛卡尔乘积,产生两表长度之积次查询,应该有足够多的约束才行。
因为多个表中的字段名可能重复,因此使用 表名.字段 语法来访问,可以在表名后起别名(空格后直接写别名)来方便查询。同时查询两张表可以综合查询两个表的字段。
例如下面的语句同样实现上面的功能:
SELECT ts.name sname,tc.name cname FROM t_student ts, t_class tc WHERE ts.class = tc.id AND tc.name = 'A';


posted on   张大大123  阅读(303)  评论(0编辑  收藏  举报

编辑推荐:
· 软件产品开发中常见的10个问题及处理方法
· .NET 原生驾驭 AI 新基建实战系列:向量数据库的应用与畅想
· 从问题排查到源码分析:ActiveMQ消费端频繁日志刷屏的秘密
· 一次Java后端服务间歇性响应慢的问题排查记录
· dotnet 源代码生成器分析器入门
阅读排行:
· ThreeJs-16智慧城市项目(重磅以及未来发展ai)
· .NET 原生驾驭 AI 新基建实战系列(一):向量数据库的应用与畅想
· Ai满嘴顺口溜,想考研?浪费我几个小时
· Browser-use 详细介绍&使用文档
· 软件产品开发中常见的10个问题及处理方法

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示