创建MySQL外键步骤
admin
2023-04-20 10:22:58
0

本文主要给大家简单讲讲创建MySQL外键步骤,相关专业术语大家可以上网查查或者找一些相关书籍补充一下,这里就不涉猎了,我们就直奔主题吧,希望创建MySQL外键步骤这篇文章可以给大家带来一些实际帮助。

1.创建表

(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);

创建MySQL外键步骤就先给大家讲到这里,对于其它相关问题大家想要了解的可以持续关注我们的行业资讯。我们的板块内容每天都会捕捉一些行业新闻及专业知识分享给大家的。

相关内容

热门资讯

燃气发电与电池储能相结合,成为... 来源:市场资讯 (来源:i商周) 孟菲斯一座xAI数据中心的燃气轮机 人工智能的用电飙升,让数据中心...
景嘉微:JM11性能大幅提升,... 有投资者在互动平台向景嘉微提问:“董秘您好!关注到近期有用户反馈公司JM11显卡推出了适配windo...
原创 v... 影像的发展进一步推动,不少品牌推出了专业影像手机,拥有2亿像素摄像头、色彩还原摄像头、影像芯片、影像...
荣耀首款自研耳夹式耳机官宣即将... 快科技5月13日消息,日前,荣耀首席营销官关海涛宣布,荣耀全场景团队自研首款耳夹式耳机马上上市,并称...
谷歌推出Googlebooks... IT之家 5 月 13 日消息,2026 年 I/O 开发者大会下周(5 月 19~20 日)召开之...
自控所推动GNC专业智能化升级 来源:滚动播报 (来源:中国航空报) 本报讯 5月6日,航空工业自控所召开 GNC+AI关键技术研发...
华电电力申请数据库访问方法专利... 国家知识产权局信息显示,华电电力科学研究院有限公司申请一项名为“数据库访问方法、装置、设备及介质”的...
苏州率先打造数据流通利用新范式 数据,作为第五大生产要素 具有流动性强、非消耗性、非均质性等特点 苏州率先打造数据流通利用新范式 夯...
伊媒披露伊美新一轮谈判5个先决... 当地时间5月12日,据伊朗法尔斯通讯社援引知情人士消息报道,伊朗对与美国新一轮谈判提出的5个先决条件...
英国将向霍尔木兹海峡多国护航行... 当地时间12日,总台记者从英国国防部获悉,英国将向在霍尔木兹海峡执行任务的多国护航行动提供无人机、战...