MySQL多表创建关联及操作
外键

现在有两张表“分类表”和“商品表”,为了表明商品属于哪个 类别,通常情况下,我们将在商品上添加一列,用来存放分类的cid信息,此列成为外键。

此时,分类表 category 称作主表,cid 成为主键。商品表 products 成为从表,category_id 成为外键。
通过主表和从表的外键描述主外键的关系,呈现的就是一对多的关系。
外键特点
1. 从表外键的值是对主键的引用。
2. 从表外键类型必须与主表主键类型一致。
声明外键约束
语法:
alter table 从表 add[constraint] [外键名称] foreign key (从表外键在字段名)references 主表(主表的主键);
[外键名称] 用于删除外键约束的,一般建议 “ _fk ”结尾。
alter table 从表 drop foreign key 外键名称
实际操作
创建数据库

创建分类表
.分类表
create table category(
cid varchar() primary key,
cname varchar()
);

创建商品表
.商品表
create table product(
pid varchar() primary key,
pname varchar(),
price double,
category_id varchar()
);

设置编码格式
set name gbk;

添加点数据
insert into category(cid,cname) values('c001','家电');
insert into category(cid,cname) values('c002','服饰');
insert into category(cid,cname) values('c003','化妆品');
insert into product(pid,pname,price,category_id) values('p001','联想','','c001');
insert into product(pid,pname,price,category_id) values('p002','海尔','','c001');
insert into product(pid,pname,price,category_id) values('p003','雷神','','c001');
insert into product(pid,pname,price,category_id) values('p004','JACK JONES','','c002');
insert into product(pid,pname,price,category_id) values('p005','真维斯','','c002');
insert into product(pid,pname,price,category_id) values('p006','花花公子','','c002');
insert into product(pid,pname,price,category_id) values('p007','劲霸','','c002');
insert into product(pid,pname,price,category_id) values('p008','香奈儿','','c003');
insert into product(pid,pname,price,category_id) values('p009','相宜本草','','c003');

最后一列 category_id 列在创建表的时候自己定义的,如果没有,则可以使用一下命令添加一列。
alter table product add category_id
链接两张表
alter table product add foreign key(category_id) references category(cid);

两张表已经关联,主表有外键约束。不能轻易删除主表数据,因为从表有他的记录。
要想解除关系,先删除从表对他有关系的数据删除,再删除主表数据。
使用外键的目的
保证数据的完整性。
注意事项
从表外键不能添加主表中不存在的记录。
主表不能删除从表中已经引用的记录。
表与表之间的关系
表语表之间的关系,说的就是表与表数据之间的关系。
一对多的关系
常见的实例:客户和订单,分类和商品,部门和员工。
一对多建表原则:在从表(多方)创建一个字段,字段作为外键指向主表的主键。
alter table 从表 add [constraint][外键名称] foreign key(从表外键在字段名) references 主表(主表的主键);

多对多的关系
常见的实例:学生和课程,商品和订单,演员和角色。
多对多关系建立表原则:需要创建第三张表,中间表中至少两个字段,这两个字段分别作为外键指向各自一方的主键。


建立关系
alter table stu_course add foreign key(sno) references stu(sid);
alter table stu_course add foreign key(sno) references course(cid);
一对一关系(了解)
在实际开发中应用不多,因为一对一可以创建成一张表。
两种建表原则:
外键唯一:主表的主键和从简的外键唯一,形成主外键关系,外键唯一 unique。
外键是主键:主表的主键和从表的主键,形成主外键关系。

多对多连接
实现如下表结构:

创建订单表
create table orders(
oid varchar() primary key,
totalprice double
);

创建经单项的表(中间表)
create table orderitem(
oid varchar(),
pid varchar()
);

关联两张表
alter table orderitem add constraint orderitem_fk foreign key(oid) references orders(oid);

alter table orderitem add constraint orderitem1_fk foreign key(pid) references product(pid);

多表查询操作
1. 交叉连接查询(基本不会用到 - 得到的是两个表的乘积)
select * from A,B
select * from category,product;

内容是乱的!第一张表3条数据,第二张表9条数据,一共 3*9 = 27 条数据。
2. 内连接查询(使用关键字 inner join -- inner可以省略)
隐式内连接
select * from A,B where 条件
select * from category c,product p where c.cid = p.category_id;

显式内连接
select * from A inner join B on 条件
select * from category inner join product on cid=category_id;

select * from category join product on cid=category_id;

3. 外连接查询(使用关键字 outer join --outer可以省略)
左外连接:left outer join
select * from A left outer join B on 条件
select * from category left join product on cid=category_id;

右外连接 right outer join
select * from A right outer join B on 条件;
select * from category right join product on cid=category_id;

左右连接的区别:
左连接:左边的数据全部查出来。category数据全部出来。
右连接:右边的数据全部查出来。product数据全部出来。

子查询
将一条 select 语句查询的结果作为另一条 select 语法的一部分(查询条件,查询结果,表等)。
例如:查询化妆品分类中上架商品详情。

查询化妆品分类
select cid from category where cname='化妆品';

利用子查询实现需求
select * from product where category_id=(select cid from category where cname="化妆品");

MySQL多表创建关联及操作的更多相关文章
- 数据库迁移(创建关联等操作) Target database is not up to date报错
使用Mysql-sqlalchemy执行数据库迁移 来更新数据库: 队长试探性的在网上找了几种方案 依然没有解决报错问题: 后来看了https://www.aliyun.com/jiaocheng/4 ...
- Mysql 数据库 表中列的操作
[1]Mysql数据库中表的列操作 Mysql中关于表中列的操作集语句: -- [1]增加一列 ) DEFAULT NULL COMMENT '目的码区号'; -- [2]增加一列,在dnis_are ...
- MySQL 数据表创建及管理
use stuinfo; -- 指定当前数据库 CREATE table if not exists student1( -- 创建数据表student1 sNo ) not NULL, sName ...
- mysql 单表下的字段操作_查询
查询的规律 查询语句限定条件越多,查询范围越小: 1.整个表 Select * From 库名.表名 2.整个表的某字段内 Select id From 库名.表名 3.整个表某字段的范围内 Sele ...
- Mysql建表+创建索引
创建表时可以直接创建索引,这种方式最简单.方便.其基本形式如下: CREATE TABLE 表名( 属性名 数据类型[完整性约束条件], 属性名 数据类型[完整性约束条件], ...... 属性名 数 ...
- mysql 单表下的字段操作
如下只介绍单表的添加.更新.删除.查询表结构操作,查询数据操作范围太大用单独的篇幅来讲解: 查看表结构 desc test_tb; Insert 插入数据 插入 = 添加 为表中指定的字段插入数据 C ...
- PYTHON MYSQL 的表创建和插入
import mysql.connector cnx = mysql.connector.connect(user='xx',password='xx++.',host='139.107.11.166 ...
- 创建ASP.NET Core MVC应用程序(3)-基于Entity Framework Core(Code First)创建MySQL数据库表
创建ASP.NET Core MVC应用程序(3)-基于Entity Framework Core(Code First)创建MySQL数据库表 创建数据模型类(POCO类) 在Models文件夹下添 ...
- python开发mysql:单表查询&多表查询
一 单表查询,以下是表内容 一 having 过滤 1.1 having和where select * from emp where id > 15; 解析过程;from > where ...
随机推荐
- 如何通过给MM修电脑培养感情
文章来自网络 在修之前,向MM反复声明,这电脑故障是有硬件和软件之分的,如果是硬件故障,例如显卡风扇不转了,显示器连线老化,显示器分辨率超出显示器指标,等等都会导致黑屏啊,这个我不回家用专门的工具是修 ...
- 笔记(tm_springboot)
1.@change="getFile($event)" 2.File imageFolder= new File(request.getServletContext().getRe ...
- 错误:pip._vendor.urllib3.exceptions.ReadTimeoutError: HTTPSConnectionPool(host='files.pythonhosted.org', port=443): Read timed out.
pip._vendor.urllib3.exceptions.ReadTimeoutError: HTTPSConnectionPool(host='files.pythonhosted.org', ...
- Linux 基本命令简单学习
平常工作中需要使用到的一些Linux基本命令,简单记录: 通过订单号查看日志: cat /---/---/xxxx20190908.log | grep C52918588112261 -C 5 ...
- PP: Overviewing evolution patterns of egocentric networks by interactive construction of spatial layouts
Problem: get an overall picture of how ego-networks evolve is a common challenging task. Existing te ...
- js中进入页面后刷新一次,且只刷新一次
让页面进行刷新,可以使用location.reload()方法,但是这种方法会让页面一直不断的刷新,这是因为当页面加载完成以后,我们让它刷新一次,那么浏览器就会重新向服务器请求数据,界面会重新加载,然 ...
- 复制文件或目录命令 - cp
1) 命令名称:cp 2) 英文原意:copy 3) 命令所在路径:/bin/cp 4) 执行权限:所有用户 5) 功能描述:复制文件或目录 语法: cp -rp [原文件或目录][目标目录] -r ...
- python 百万级别类实例实现节省内存
# 案例: ''' 某网络游戏中,定义了玩家类Player(id,name,status) 每当有一个玩家,就会在服务器创建一个Player实例 当在线人数过多时,将产生大量实例(百万级别),消耗内存 ...
- Android 系统签名
在做android产品开发的时候,很多时候都需要使用系统签名(比如在使用uid,APK升级的时候),所以,android提供给我们自定义签名文件的工具.这里将流程记录下来: 1.进入/android_ ...
- CentOS7.5下基于FTP服务的局域网yum源搭建
实验环境 yum源服务器和yum客户端都处于同一局域网之中 yum源服务器 hostname:zabbix OS版本:CentOS 7.5 IP:192.168.101.201 yum客户端 host ...