MySQL连表操作之一对多

2024-01-26 18:04
文章标签 mysql 操作 database 连表

本文主要是介绍MySQL连表操作之一对多,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

MySQL连表操作之一对多

目录

  • 引入
  • 外键
    • Navicat创建外键
    • 使用外键
    • SQL命令创建外键
    • 代码删除外键
    • 代码增加外键
    • 通过外键进行数据操作

正文

回到顶部

引入

当我们在数据库中创建表的时候,有可能某些列中值内容量很大,而且重复。

例子:创建一个学生表,按学校年纪班级分,表的内容大致如下:

idnamepartment
1xxxx学校x年级x班级
2ooox学校x年级x班级
3zzzz学校x年级x班级
4dddy学校x年级x班级

我们看出来对应的partment对应的值很长,而且重复量很大,这样就很不合适。

因此我们考虑将复杂重复的部分单独拿出来分成2个表:

第一张表:

idcaption
1x学校x年级x班级
2y学校x年级x班级
3z学校x年级x班级

第二张表在之前的基础上修改的:

idnamepartment
1xxx1
2ooo2
3zzz3
4ddd1

这样看起来就很简洁了,我们将很长的且重复的部分拿出来,然后规定编号,创建学生表的时候,学生对应的partment只需要取学校对应的id便可,这样同时这2张表也就会关联起来。

说明:

1、他们的关联关系;表2中的partment和表1的id联系再一起。

2、表一的数据会对应表2中的多条数据,这就叫一对多

问题:此时,两张表是相对独立的,都可以各自插入自己的数据,这样做很合适的,并没实质行的关联?

因此,必须要将其限制。表二的partment数据必须是表一中有的,不然,就不让其增加。

这里(partment)就引入了一个名词 —- 外键

回到顶部

外键

说明:
1、外键:一个表接收另一个表的主键。
2、partment外键的是表一中的nid。
3、当我们创建了外键,则系统变默认会为我们添加,相应的约束,如:表二中的partment数据必须是表一中nid有的;表二和表一就关联起来了。

Navicat创建外键

创建part表:

1481267881120

创建person表:

1481267949167

外键的创建注意点:
创建外键时,互相对应的表中的数据类型必须一样

创建外键

1、首先在要创建外键的表上右键,选设计表。
2、进入设计表,在右边显示表行信息,然后点击外键:

1481268565436

3、选择字段,会出现一个选择框,选择你要设置外键的列;

1481268675355

4、选择参考表,选择要外键要关联的表,

1481268768575

说明:
参数数据库:因为两个数据库在同意目录下,所以这里可以不用选择;默认是同目录下的。

5、选择参考字段;选择参考表中要设为外键的列;

1481268901706

注意:
外键的创建,连个表中关联的列的数据类型必须一样,不然不能成功。

6、保存CTRL + S

使用外键

此时part中没有数据,如果此时你在person中添加数据,结果:

1481269064394

在part中添加数据,结果:

1481269148396

此时再在,person中添加数据:

1481269219718

注意:

这里不能输入part中nid没有的值,不然也会报错。

1481269304129

SQL命令创建外键

创建part:

create table part(nid int not null auto_increment primary key,caption varchar(32) not null
)

 part

创建person:

create table person(nid int not null auto_increment,name varchar(32) default null,email varchar(32) default null,part_nid int,primary key(nid),constraint fk_person_part foreign key (part_nid) references part(nid)
)

 person

创建完之后外键对应代码的关系:

image

分析:
1、从名字可以看出代码对应的是什么位置的。
2、图中名(C对应代码中的CONSTRAINT)这行可以不用设,系统会默认帮我设置,但是最好设置,如果要删除外键的时候,就可以通过这个名字进行相应的操作

代码删除外键

01

alter table person1drop foreign key fk_person1_part1;

代码增加外键

01

alter table person1add constraint fk_p1_t1foreign key (part1_nid)references part1(nid);

通过外键进行数据操作

part表:

1481274072447

person表:

1481274100625

需求:要找出person表中属于x学校的人?

1、之前学的办法:

  • 1、先去part中获取x对应的nid
  • 2、然后再通过这个nid与parson中part_id对用的关系,查找出对应的name

01

select name from personwhere part_idin (select nid form partwhere caption ="x")

2、链表方法 left join

left join

使用连表提供的方法,left join操作代码:

01

select *from personleft join parton person.part_id = part.nid

结果显示:

1481274965703

分析:
left join:相当于将part表匹配的部分直接移动到person的列后面,组合起来显示。

既然内容都合并了,那么此时我们再加上判断,就可以将要的数据获取了。

代码1:

01

select *from personleft join parton person.part_id = part.nidwhere part.caption ="x"

结果:

1481275260873

说明:

之前我们用的 * 获取的是全部的信息,如果我们获取指定的信息,可以将其修改。

如:只获取person的name代码:

01

select person.name from personleft join parton person.part_id = part.nidwhere part.caption ="x"

结果:

1481275364629

注意:
join连接的条件,使用 on 进行对接的,条件写在on后面。

01

Aleft join Bon a.xx = b.xx

left join的特点:
1、以A为主
2、将A中的所有数据罗列
3、B则只显示与A相对应的数据

问题:验证我们说的谁在前就谁为主,谁的数据就全部显示,我们将person和part换个位置?

01

select *from partleft join personon person.part_id = part.nid;

结果:

1481292040108

right join

在谁显示所有数据的上来看,他和left join刚好相反,以后面的表为主,显示其所有的数据。

inner join

会将没有建立关系的数据忽略掉。不管谁在前,结果都是一样。

01

select *from personinner join parton person.part_id = part.nid;

结果:

1481292750984

总结:
1、这几个join可以写多个的,意思就是一个表可以同时有多个外键。

2、当选择的列名,是所有表中唯一的话,可以不用写前缀的表名。如:person.part_id就可以直接写成part_id.

3、上面的part表,有个别名叫,字典表

这篇关于MySQL连表操作之一对多的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/647616

相关文章

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

oracle DBMS_SQL.PARSE的使用方法和示例

《oracleDBMS_SQL.PARSE的使用方法和示例》DBMS_SQL是Oracle数据库中的一个强大包,用于动态构建和执行SQL语句,DBMS_SQL.PARSE过程解析SQL语句或PL/S... 目录语法示例注意事项DBMS_SQL 是 oracle 数据库中的一个强大包,它允许动态地构建和执行

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

SQL 中多表查询的常见连接方式详解

《SQL中多表查询的常见连接方式详解》本文介绍SQL中多表查询的常见连接方式,包括内连接(INNERJOIN)、左连接(LEFTJOIN)、右连接(RIGHTJOIN)、全外连接(FULLOUTER... 目录一、连接类型图表(ASCII 形式)二、前置代码(创建示例表)三、连接方式代码示例1. 内连接(I

在MySQL执行UPDATE语句时遇到的错误1175的解决方案

《在MySQL执行UPDATE语句时遇到的错误1175的解决方案》MySQL安全更新模式(SafeUpdateMode)限制了UPDATE和DELETE操作,要求使用WHERE子句时必须基于主键或索引... mysql 中遇到的 Error Code: 1175 是由于启用了 安全更新模式(Safe Upd

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

MySql死锁怎么排查的方法实现

《MySql死锁怎么排查的方法实现》本文主要介绍了MySql死锁怎么排查的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录前言一、死锁排查方法1. 查看死锁日志方法 1:启用死锁日志输出方法 2:检查 mysql 错误