第二百八十节,MySQL数据库-外键链表之一对多,多对多
MySQL数据库-外键链表之一对多,多对多
外键链表之一对多
外键链表:就是a表通过外键连接b表的主键,建立链表关系,需要注意的是a表外键字段类型,必须与要关联的b表的主键字段类型一致,否则无法创建索引
一对多:就是b表的某一个字段值对应a表外键里的多个值,前提是a表要与b表链表

用Navicat 软件可视化外键链表
1、a表里创建外键连接b表的主键,首先检查a表里要设置外键的字段、和b表里的主键字段数据类型是否一致,两者数据类型必须一致,不然无法建立索引【重点】
2、Navicat 软件可视化打开a表,设计表-外键里设置

3、设置后a表和b表就建立了外键链表,可以在a表的外键字段看b表的主键字段,说明他们两者的链表关系建立

外键链表约束
a表和b表链表后,两表之间建立了链表关系,a表受b表约束,也就是当a表添加或者修改一条数据时、这条数据的外键字段值如果是b表主键字段不存在的,将无法添加,会报错【重点】

sql语句创建表并且设置外键链表
KEY 外键名称 (外键字段), #设置外键名称
CONSTRAINT 外键名称 FOREIGN KEY (外键字段) REFERENCES 连接表名称 (连接表主键字段) #设置外键链表
-- CREATE TABLE `usr` (
-- `id` int(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
-- `yhm` char(255) NOT NULL COMMENT '用户名',
-- `xb` char(255) NOT NULL COMMENT '性别',
-- `nl` int(255) NOT NULL COMMENT '年龄',
-- `fzu` int(255) NOT NULL COMMENT '分组',
-- PRIMARY KEY (`id`),
-- KEY 外键名称 (外键字段), #设置外键名称
-- CONSTRAINT 外键名称 FOREIGN KEY (外键字段) REFERENCES 连接表名称 (连接表主键字段) #设置外键链表
-- ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='用户表-连表usr_fzu'; CREATE TABLE `usr` (
`id` int(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
`yhm` char(255) NOT NULL COMMENT '用户名',
`xb` char(255) NOT NULL COMMENT '性别',
`nl` int(255) NOT NULL COMMENT '年龄',
`fzu` int(255) NOT NULL COMMENT '分组',
PRIMARY KEY (`id`),
KEY `usr-usr_fzu` (`fzu`),
CONSTRAINT `usr-usr_fzu` FOREIGN KEY (`fzu`) REFERENCES `usr_fzu` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='用户表-连表usr_fzu';
sql语句删除表的外键链表
ALTER TABLE 删除外键的表名称 DROP FOREIGN KEY 创建外键时的外键名称;#删除外键
-- ALTER TABLE 删除外键的表名称 DROP FOREIGN KEY 创建外键时的外键名称; ALTER TABLE usr DROP FOREIGN KEY usr_usr_fzu;
sql语句创建表的外键链表
ALTER TABLE 要创建外键的表 ADD CONSTRAINT 设置外键名称 FOREIGN KEY (外键字段) REFERENCES 要连接的表名称 (要连接表的主键id);#创建外键
-- ALTER TABLE 要创建外键的表 ADD CONSTRAINT 设置外键名称 FOREIGN KEY (外键字段) REFERENCES 要连接的表名称 (要连接表的主键id); ALTER TABLE usr ADD CONSTRAINT usr_usr_fzu FOREIGN KEY (fzu) REFERENCES usr_fzu (id);
sql语句连表查询
LEFT JOIN:左连接的意思
ON:接通
SELECT 显示字段 FROM 外键表 LEFT JOIN 连接表 ON 外键表.外键字段 = 连接表.连接表主键; #链表查询,将连接表的信息组合到外键表一起显示出来
a表 LEFT JOIN b表 ON a表.外键字段 = b表.主键字段
-- LEFT JOIN:左连接的意思
-- ON:接通
-- SELECT 显示字段 FROM 外键表 LEFT JOIN 连接表 ON 外键表.外键字段 = 连接表.连接表主键; #链表查询,将连接表的信息组合到外键表一起显示出来
-- a表 LEFT JOIN b表 ON a表.外键字段 = b表.主键字段 SELECT * FROM usr LEFT JOIN usr_fzu ON usr.fzu = usr_fzu.id;
外键表

连接表

将连接表的信息组合到外键表一起显示出来

sql语句连表加WHERE条件查询
a表 LEFT JOIN b表 ON a表.外键字段 = b表.主键字段 WHERE b表.字段 = '值';
举例:查询a表的外键值、属于b表主键值对应的、某个字段值的所有数据

-- a表 LEFT JOIN b表 ON a表.外键字段 = b表.主键字段 WHERE b表.字段 = '值'; SELECT * FROM usr LEFT JOIN usr_fzu ON usr.fzu = usr_fzu.id WHERE usr_fzu.usr_fzu = 'A';

可以看到只查询了属于A的数据
sql语句连表关键字说明
连表关键字有3种:
LEFT JOIN
RIGHT JOIN
INNER JOIN
使用方法:
a表 LEFT JOIN b表 ON a表.xx = b表.xx
a表 RIGHT JOIN b表 ON a表.xx = b表.xx
a表 INNER JOIN b表 ON a表.xx = b表.xx
注意:a表是外键表,b表是连接表
它们连表之间的区别
LEFT JOIN :以LEFT JOIN前面的表为主,前面的表所有数据都会显示
a表 LEFT JOIN b表:以a表为主,只显示与a表有关联的b表数据


SELECT * FROM usr LEFT JOIN usr_fzu ON usr.fzu = usr_fzu.id;

可以看到b表里的usr_fzu字段的C、D没有显示
b表 LEFT JOIN a表:以b表为主,b表里与a表无关联数据也会显示

SELECT * FROM usr_fzu LEFT JOIN usr ON usr.fzu = usr_fzu.id;

可以看到b表里的usr_fzu字段里与a表无关联的也显示了
RIGHT JOIN:是以RIGHT JOIN后面的表为主,显示后面表的所有数据
a表 LEFT JOIN b表:以b表为主
b表 LEFT JOIN a表:以a表为主
以上面列子相同,就不在举例了
INNER JOIN:不以哪个表为主,只要是两个表数据之间无关联的都不显示
a表 LEFT JOIN b表:两个表数据之间无关联的都不显示
b表 LEFT JOIN a表:两个表数据之间无关联的都不显示
以上面列子相同,就不在举例了
一张表两个外键链表



一张表两个外键链表的查询
SELECT
*
FROM
usr
LEFT JOIN usr_fzu ON usr.usr_fzu_id = usr_fzu.id
LEFT JOIN usr_yans ON usr.usr_yans_id = usr_yans.id;

一张表两个外键链表的WHERE条件查询
SELECT
*
FROM
usr
LEFT JOIN usr_fzu ON usr.usr_fzu_id = usr_fzu.id
LEFT JOIN usr_yans ON usr.usr_yans_id = usr_yans.id
-- 链表查询,用户在usr_fzu.fzu = 'B' 并且在 usr_yans.yans = 'hong' 的用户
WHERE usr_fzu.fzu = 'B' AND usr_yans.yans = 'hong'

重点:外键链表,无论是外键连接了几张表,其本质就是将外键连接的表组合到当前表成为一张表,来各种条件查询
重点:一般在链表查询字段、和链表取数据字段时,需要加上所操作的表名称.字段名称,如:usr_yans.yans(usr_yans表的yans字段)
字典表:外键连接的表一般被称为字典表
外键链表之多对多
1、多对多是通过一个关系表外键链表,将多个表建立关系
2、可以是1条数据对应多条数据,或者多条数据对应1条数据
3、也可以是多条数据对应多条数据
举例:创建男女恋爱关系多对多
一个男人可能跟多个女人谈过恋爱,一个女人可能跟多个男人谈过恋爱,通过链表多对多统计出某个男人有跟哪些女人谈过恋爱
1、建立一张表存放男人信息
2、建立一张表存放女人信息
3、建立一张表外键连接这两张男女信息表,记录男女的恋爱关系

创建外键链表关系

将3张表组合一起查询
SELECT
*
FROM
nan_nv
LEFT JOIN nan ON nan_nv.nan_id = nan.id
LEFT JOIN nv ON nan_nv.nv_id = nv.id;

将3张表组合一起加WHERE条件查询
如:查询与张三有过恋爱关系的女人
SELECT
*
FROM
nan_nv
LEFT JOIN nan ON nan_nv.nan_id = nan.id
LEFT JOIN nv ON nan_nv.nv_id = nv.id
WHERE nan.nan = '张三(男)';

第二百八十节,MySQL数据库-外键链表之一对多,多对多的更多相关文章
- MySQL数据库-外键链表之一对多,多对多
外键链表之一对多 外键链表:就是a表通过外键连接b表的主键,建立链表关系,需要注意的是a表外键字段类型,必须与要关联的b表的主键字段类型一致,否则无法创建索引 一对多:就是b表的某一个字段值对应a表外 ...
- 第二百八十二节,MySQL数据库-MySQL视图
MySQL数据库-MySQL视图 1.视图是一个虚拟表(非真实存在),其本质是[根据SQL语句获取动态的数据集,并为其命名],用户使用时只需使用[名称]即可获取结果集,并可以将其当作表来使用. 2.也 ...
- 第二百八十九节,MySQL数据库-ORM之sqlalchemy模块操作数据库
MySQL数据库-ORM之sqlalchemy模块操作数据库 sqlalchemy第三方模块 sqlalchemysqlalchemy是Python编程语言下的一款ORM框架,该框架建立在数据库API ...
- 第三百八十节,Django+Xadmin打造上线标准的在线教育平台—将所有app下的models数据库表注册到xadmin后台管理
第三百八十节,Django+Xadmin打造上线标准的在线教育平台—将所有app下的models数据库表注册到xadmin后台管理 将一个app下的models数据库表注册到xadmin后台管理 重点 ...
- MySQL数据库--外键约束及外键使用
什么是主键.外键关系型数据库中的一条记录中有若干个属性,若其中某一个属性组(注意是组)能唯一标识一条记录,该属性组就可以成为一个主键. 比如: 学生表(学号,姓名,性别,班级) 其中每个学生的学号是唯 ...
- 第二百八十六节,MySQL数据库-MySQL事务操作(回滚)
MySQL数据库-MySQL事务操作(回滚) 事务用于将某些操作的多个SQL作为原子性操作,一旦有某一个出现错误,即可回滚到原来的状态,从而保证数据库数据完整性. 举例:有这样一张表 从表里可以看出张 ...
- 第二百八十五节,MySQL数据库-MySQL函数
MySQL数据库-MySQL函数 1.MySQL内置函数 SELECT执行函数,后面跟要执行的函数 CHAR_LENGTH(str)函数:返回字符串的字符长度 -- CHAR_LENGTH(str)函 ...
- 第二百八十四节,MySQL数据库-MySQL触发器
MySQL数据库-MySQL触发器 对某个表进行[增/删/改]操作的前后如果希望触发某个特定的行为时,可以使用触发器,触发器用于定制用户对表的行进行[增/删/改]前后的行为. 1.创建触发器基本语法 ...
- 第二百八十八节,MySQL数据库-索引、limit分页、执行计划、慢日志查询
MySQL数据库-索引.limit分页.执行计划.慢日志查询 索引,是数据库中专门用于帮助用户快速查询数据的一种数据结构.类似于字典中的目录,查找字典内容时可以根据目录查找到数据的存放位置,然后直接获 ...
随机推荐
- One or more files are in a conflicted state
http://blog.csdn.net/caiwenfeng_for_23/article/details/37501249 解决代码冲突 如果commit时出现“You have to updat ...
- Creating a Unity Game for Windows 8
原地址:http://www.davebost.com/2013/08/30/creating-a-unity-game-for-windows-8 The recent release of Uni ...
- 〖QT编程〗在Qt编程中使用/显示中文编码
在main.cpp中添加: #include "QTextCodec" QTextCodec *codec = QTextCodec::codecForName("Sys ...
- ueditor使用遇到的问题
1.文件没法上传,需要引入ueditor官网说的那几个jar包才行 2.上传的文件读不出来,路径不对,需要把config.json里面的所有[“”]替换成[/你的项目路径],即把所有的Prefix路径 ...
- Linode之使用UE实现SSH连接
在Linode上建立了节点后,选择对应的操作系统(我选用的是Ubuntu 12.04 LTS),然后启动就可以.详细能够參见该文(https://library.linode.com/getting- ...
- unity, multi collider
比如下面鸭子模型,只用一个box collider难以很好地吻合其的外形. 我们可以为它添加两个box collider,如下图所示: 注意: 1,colliders一定要添加在模型根节点(即图中do ...
- 并发登录人数控制--Shiro系列(二)
为了安全起见,同一个账号理应同时只能在一台设备上登录,后面登录的踢出前面登录的.用Shiro可以轻松实现此功能. shiro中sessionManager是专门作会话管理的,而sessinManage ...
- Openstack 03 - Nova Compute
1.前言 非常早之前就開始着手写Openstack 系列的博客了,在写了总体架构和Keystone之后,准备写Nova,可是每次写到一半,自己心里就认为不踏实,由于似乎我并没有真正理解Nova,或者说 ...
- Xilinx-7Series-FPGA高速收发器使用学习—TX发送端介绍
每一个收发器拥有一个独立的发送端,发送端有PMA(Physical Media Attachment,物理媒介适配层)和PCS(PhysicalCoding Sublayer,物理编码子层)组成,其中 ...
- cygwin 运行java的一些记录
javac编译没问题,但是java执行就不行,处理方式如下 其实就是把宿主机下的java.exe在cygwin下搞一个快捷方式 关于路径问题,可以使用cygpath命令进行宿主机和cygwin间的转换 ...