MySQL连表操作之一对多
引入
当我们在数据库中创建表的时候,有可能某些列中值内容量很大,而且重复。
例子:创建一个学生表,按学校年纪班级分,表的内容大致如下:
id | name | partment |
1 | xxx | x学校x年级x班级 |
2 | ooo | x学校x年级x班级 |
3 | zzz | z学校x年级x班级 |
4 | ddd | y学校x年级x班级 |
我们看出来对应的partment对应的值很长,而且重复量很大,这样就很不合适。
因此我们考虑将复杂重复的部分单独拿出来分成2个表:
第一张表:
id | caption |
1 | x学校x年级x班级 |
2 | y学校x年级x班级 |
3 | z学校x年级x班级 |
第二张表在之前的基础上修改的:
id | name | partment |
1 | xxx | 1 |
2 | ooo | 2 |
3 | zzz | 3 |
4 | ddd | 1 |
这样看起来就很简洁了,我们将很长的且重复的部分拿出来,然后规定编号,创建学生表的时候,学生对应的partment只需要取学校对应的id便可,这样同时这2张表也就会关联起来。
说明:
1、他们的关联关系;表2中的partment和表1的id联系再一起。
2、表一的数据会对应表2中的多条数据,这就叫一对多。
问题:此时,两张表是相对独立的,都可以各自插入自己的数据,这样做很合适的,并没实质行的关联?
因此,必须要将其限制。表二的partment数据必须是表一中有的,不然,就不让其增加。
这里(partment)就引入了一个名词 —- 外键
外键
说明:
1、外键:一个表接收另一个表的主键。
2、partment外键的是表一中的nid。
3、当我们创建了外键,则系统变默认会为我们添加,相应的约束,如:表二中的partment数据必须是表一中nid有的;表二和表一就关联起来了。
Navicat创建外键
创建part表:
创建person表:
外键的创建注意点:
创建外键时,互相对应的表中的数据类型必须一样
。
创建外键
1、首先在要创建外键的表上右键,选设计表。
2、进入设计表,在右边显示表行信息,然后点击外键:
3、选择字段,会出现一个选择框,选择你要设置外键的列;
4、选择参考表,选择要外键要关联的表,
说明:
参数数据库:因为两个数据库在同意目录下,所以这里可以不用选择;默认是同目录下的。
5、选择参考字段;选择参考表中要设为外键的列;
注意:
外键的创建,连个表中关联的列的数据类型必须一样,不然不能成功。
6、保存CTRL + S
使用外键
此时part中没有数据,如果此时你在person中添加数据,结果:
在part中添加数据,结果:
此时再在,person中添加数据:
注意:
这里不能输入part中nid没有的值,不然也会报错。
SQL命令创建外键
创建part:
创建person:
person
创建完之后外键对应代码的关系:
分析:
1、从名字可以看出代码对应的是什么位置的。
2、图中名(C对应代码中的CONSTRAINT)这行可以不用设,系统会默认帮我设置,但是最好设置,如果要删除外键的时候,就可以通过这个名字进行相应的操作。
代码删除外键
- alter table person1 drop foreign key fk_person1_part1;
代码增加外键
- alter table person1 add constraint fk_p1_t1 foreign key (part1_nid) references part1(nid);
通过外键进行数据操作
part表:
person表:
需求:要找出person表中属于x学校的人?
1、之前学的办法:
- 1、先去part中获取x对应的nid
- 2、然后再通过这个nid与parson中part_id对用的关系,查找出对应的name
- select name from person where part_id in (select nid form part where caption = "x")
2、链表方法 left join
left join
使用连表提供的方法,left join操作代码:
- select * from person left join part on person.part_id = part.nid
结果显示:
分析:
left join:相当于将part表匹配的部分直接移动到person的列后面,组合起来显示。
既然内容都合并了,那么此时我们再加上判断,就可以将要的数据获取了。
代码1:
- select * from person left join part on person.part_id = part.nid where part.caption = "x"
结果:
说明:
之前我们用的
*
获取的是全部的信息,如果我们获取指定的信息,可以将其修改。如:只获取person的name代码:
- select person.name from person left join part on person.part_id = part.nid where part.caption = "x"
结果:
注意:
join连接的条件,使用 on 进行对接的,条件写在on后面。
- A left join B on a.xx = b.xx
left join的特点:
1、以A为主
2、将A中的所有数据罗列
3、B则只显示与A相对应的数据
问题:验证我们说的谁在前就谁为主,谁的数据就全部显示,我们将person和part换个位置?
- select * from part left join person on person.part_id = part.nid;
结果:
right join
在谁显示所有数据的上来看,他和left join刚好相反,以后面的表为主,显示其所有的数据。
inner join
会将没有建立关系的数据忽略掉。不管谁在前,结果都是一样。
- select * from person inner join part on person.part_id = part.nid;
结果:
总结:
1、这几个join可以写多个的,意思就是一个表可以同时有多个外键。2、当选择的列名,是所有表中唯一的话,可以不用写前缀的表名。如:person.part_id就可以直接写成part_id.
3、上面的part表,有个别名叫,字典表
MySQL连表操作之一对多的更多相关文章
- MySQL 数据表操作
MySQL 数据表操作 创建MySQL数据表需要以下信息: -表名: -表字段名: -定义每个表字段: 一.创建数据表 1)mysql> create table table_name (c ...
- Database学习 - mysql 数据库 表操作
mysql 数据库 表操作 创建数据表 基本语法格式: 创建数据表: create table 表名( 字段名 datatype 约束, 字段名 datatype 约束, ...... ) 修改表名 ...
- mysql 数据表操作 目录
mysql 数据表操作 存储引擎介绍 mysql 使用存储引擎 mysql 数据表的增删改查 mysql 数据类型 mysql 约束条件
- 数据库 MySQL 之 表操作、存储引擎
数据库 MySQL 之 表操作.存储引擎 浏览目录 创建(复制) 删除 修改 查询 存储引擎介绍 一.创建(复制) 1.语法: 1 2 3 4 5 CREATE TABLE 表名( 字段名1 ...
- Mysql 库表操作初识
Mysql 库表操作初识 终端登录mysql 这里只演示win下, cmd 终端. 至于怎么在win下, linux, mac安装, 感觉这是一个入门级的百度搜索问题, 安装都搞不定, 确实有点尴尬, ...
- mysql连表操作是先连表还是先查询条件
mysql连表操作是先连表还是先查询条件 一.总结 一句话总结: 连表操作时:先根据查询条件和查询字段确定驱动表,确定驱动表之后就可以开始连表操作了,然后再在缓存结果中根据查询条件找符合条件的数据 1 ...
- MySQL<多表操作>
多表操作 外键 什么是外键 外键是指引用另一个表中的一列或多列,被引用的列应该具有主键约束或唯一性约束. 外键用于建立和加强两个表数据之间的链接. 为表添加外键约束 想要真正连接两个表的数据,就需要为 ...
- Django框架第七篇(模型层)--多表操作:一对多/多对多增删改,跨表查询(基于对象、基于双下划线跨表查询),聚合查询,分组查询,F查询与Q查询
一.多表操作 一对多字段的增删改(book表和publish表是一对多关系,publish_id字段) 增 create publish_id 传数字 (publish_id是数据库显示的字段名 ...
- mysql单表操作与多表操作
0. null和notnull: 使用null的时候: create table t8( id int auto_increment primary key, name varchar(32), em ...
随机推荐
- ORACLE关闭启动的诡异错误
在自己虚拟机搭建的ORACLE数据库环境下,折腾捣鼓做实验时,不知道什么特殊的改动.操作导致从SQL*PLUS里启动数据库实例时,报如下错误: 然后用startup nomout启动时,任然报ORA- ...
- Symantec Backup Exec 2012 Agent for Linux 卸载
本文介绍一下如何卸载Symantec Backup Exec 2012 Agent for Linx.首先我们来看看Symantec_Backup_Exec2012管理员手册的文档介绍: 卸载 Age ...
- Echarts 之三 —— 地市联动数据统计二
一.简介 除了是一个地图之外,我们也可以使用多地图进行地市.区县联动数据统计.需求如下:展示整改广东省的地图,并显示统计信息,当点击某一个地市的时候,就显示该地市的地图,并统计该地市区县的数据信息.二 ...
- 崔用志-微信开发-java版本
崔用志-微信开发-java版本 今天看到一些关于微信开发的知识蛮好的博客,分享给大家,希望对大家有帮助. 微信开发准备(一)--Maven仓库管理新建WEB项目 微信开发准备(二)--springmv ...
- C++ - 静态成员函数
c++中静态成员函数属于整个类, 而不是某个对象,因此不需要创建对象就可以访问 1.出现在类体外的函数定义不能指定关键字static:2.静态成员之间可以相互访问,包括静态成员函数访问静态数据成员和访 ...
- WPF 依赖属性
依赖属性,简单的说,在WPF控件应用过程中,界面上直接可以引用的属性 如:<Button Content="aaa"></Button> Content称为 ...
- Android资源(图片)命名规范
(转自:http://www.jb51.net/article/38796.htm) 图片命名注意: 1,不能以下划线("_")开头: 2,以数字加下划线("[0-9]_ ...
- 使用ab进行压力测试详解
ab是apache自带的压力测试工具,非常好用.转载几篇对ab工具的详细使用的博文.猛击下面的链接地址 http://www.365mini.com/page/apache-benchmark.htm ...
- 全透明Activity
第一步:在/res/values/styles里面添加如下代码: <style name="translucent"> <item name="andr ...
- 附加数据库后无法创建发布,error 2812 解决
日前,由于业务需要,我要把一个数据库直接迁移到新的实例上 用的方法比较古老,就是直接停旧服务器,将数据文件复制到新服务器上,附加数据库 当然这个附加没有什么可说的了,但是在附加后需要将原来库上的发布重 ...