MySQL外键
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了MySQL外键,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2526字,纯文字阅读大概需要4分钟。
内容图文
![MySQL外键](/upload/InfoBanner/zyjiaocheng/1187/e60ddb4e7d1f4dc7940da67e2663bca8.jpg)
(1)外键:FOREIGN KEY(ordersid) references orders(id)
在建表过程中
create table team(
id int primary key auto_increment,
name varchar(40)
);create table star(
id int ,
name varchar(40),
team_id int,
foreign key (team_id) references team(id)
);insert into team values(null,‘Toronto Raptors‘),(null,‘Milwaukee Bucks‘),(null,‘Boston Celtics‘),(null,‘Golden State Warriors‘),(null,‘Oklahoma City Thunder‘),(null,‘Dallas Mavericks‘);
insert into star values(2,‘科怀-伦纳德‘,1),(7,‘洛瑞‘,1),(34,‘阿德托昆博‘,2),(22,‘米德尔顿‘,2),(11,‘欧文‘,3),(20,‘海沃德‘,3),(35,‘杜兰特‘,4),(30,‘库里‘,4),(0,‘威斯布鲁克‘,5),(13,‘保罗-乔治‘,5),(77,‘卢克-东契奇‘,6),(41,‘诺维斯基‘,6);
(2)在表已经存在,通过修改表的语句增加外键
ALTER TABLE 表名 ADD constraint FK_ID#外键名 foreign key(外键字段名) references 外表表名(主字段名)
(3)删除外键
alter table 表名 drop foreign key 外键名;
(4)操作关联表
多对多关系:新建一张第三方关系表,保存两张表的主键作为外键,存储两张表主键主键之间的对应关系,来保存两张表之间的关系
一对一:在从表建立外键
2.连接查询
(1)多表设计多表查询
select * from team,star; #两张表相乘结果
select * from team,star where team.id = star.team_id; #过滤
~内连接:自然连接
SELECT 查询字段 FROM 表1 [INNER] JOIN 表2 ON 表1.关系字段 = 表2.关系字段
select * from team inner join star on team.id = star.team_id;
~左外连接查询:在内链接的基础上增加上左边表有而右边表没有的记录
select * from team left join star on team.id = star.team_id;
~右外连接查询,在内链接的基础上增加上右边表有而左边表没有的记录
select * from team right join star on team.id = star.team_id;
~全连接查询:
select * from team full join star on team.id = star.team_id;#mysql不支持
但是支持union
select from team left join star on team.id = star.team_id
union
select from team right join star on team.id = star.team_id;
~查询3号球队的名称和其中的球员的姓名
select * from team inner join star on team.id = star.team_id where team_id = 3;
select team.name 队名,star.name 球员 from team inner join star on team.id = star.team_id where team_id = 3;
3.子查询
(1)带IN关键字的子查询,内层查询语句仅仅返回一个数据列,这个数据列中的值将供外层查询语句语句进行比较操作,即嵌套查询
~查询号码大于20的球员所属的部门
select name from team where id in (select team_id from star where id>20);
~查询不大于20的球员所属的部门
select name from team where id not in (select team_id from star where id = 20);
(2)带EXISTS关键字的子查询:子查询不返回任何数据,只返回Ture or False ,为Ture时才执行外查询
select * from team where exists (select team_id from star where id > 20); #两张表的字段名要一样
(3)带any关键字的子查询:ANY关键字表示满足其中任意一个条件即可
select * from team where id > any (select team_id from star where id = 20);
(4) 带ALL关键字的子查询:需要同时满足内查询所有条件
select * from team where id > all (select team_id from star where id > 20);
select * from team where id > all (select team_id from star where id < 10);
表内数据不能为空
(5)带比较运算符的子查询 < > <= >= = <>
select * from team where id > (select team_id from star where id =0);
原文:http://blog.51cto.com/13742773/2328539
内容总结
以上是互联网集市为您收集整理的MySQL外键全部内容,希望文章能够帮你解决MySQL外键所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。