外键 (foreign key)

  1. ## 外键
  2. ```mysql
  3. # 作者(author):id,name,sex,age,mobile, detail_id
  4. # 作者详情(author_detail): id,info,address
  5. # 1、外键的 字段名 可以自定义(名字随意),通常命名规范(关联表_关联字段)
  6. # 2、外键要通过 foreign key 语法建立表与表之间的关联
  7. # 3、foreign key(所在表的外键字段) references 关联表(关联字段)
  8. # eg:foreign key(detail_id) references author_detail(id)
  9. # 4、级联关系
  10. # 级联更新 on update cascade
  11. # 级联删除 on delete cascade
  12. # 重点:外键字段本身可以唯一或不唯一,但是外键关联的字段一定唯一

字段操作

  1. create table tf1(
  2. id int primary key auto_increment,
  3. x int,
  4. y int
  5. );
  6. # 修改
  7. alter table tf1 modify x char(4) default '';
  8. alter table tf1 change y m char(4) default '';
  9. # 增加
  10. mysql>: alter table 表名 add 字段名 类型[(长度) 约束]; # 末尾
  11. eg>: alter table tf1 add z int unsigned;
  12. mysql>: alter table 表名 add 字段名 类型[(宽度) 约束] first; # 首位
  13. eg>: alter table tf1 add a int unsigned first;
  14. mysql>: alter table 表名 add 字段名 类型[(宽度) 约束] after 旧字段名; # 某字段后
  15. eg>: alter table tf1 add xx int unsigned after x;
  16. mysql>: alter table 表名 drop 字段名; # 删除字段
  17. eg>: alter table tf1 drop a;

多表关系

  1. """
  2. 一对一:丈夫-妻子,用户-身份证,作者-作者详情
  3. 一对多:部门-员工,班级-学生,书-出版社
  4. 多对多:老师-班级,课程-学生,出版社-作者
  5. """
  6. # 书 - 出版社 - 作者 - 作者详情 外键分布
  7. # 外键是 建立表与表关联 的字段,通常 一个表的外键 是 另一个表的主键(唯一键也可以)
  8. # 一对一:外键在任何一方都可以,此时外键要设置 唯一键
  9. """
  10. 作者(author):id,name,sex,age,mobile
  11. 作者详情(author_detail): id,info,address,author_id
  12. ----------------------------------------------------
  13. 作者(author):id,name,sex,age,mobile, detail_id
  14. 1 Tom 1
  15. 2 Bom 2
  16. 3 Bob 3
  17. 作者详情(author_detail): id,info,address
  18. 1 Tom_info
  19. 2 Bom_info
  20. """
  21. # 一对多:外键必须放在多的一方,此时外键值不唯一
  22. """
  23. 书(book):id,name,price,publish_id
  24. 1 西游记 1
  25. 2 东游记 2
  26. 3 西厢记 1
  27. 4 流浪记 1
  28. 出版社(publish): id,name,address,phone
  29. 1 老奶奶出版社
  30. 2 小奶奶出版社
  31. """
  32. # 多对多:一定要创建第三张表(关系表),每一个外键值不唯一,看可以多个外键建立联合唯一
  33. """
  34. 作者(author):id, name, age
  35. 出版社(publish):id, name, address
  36. 作者与出版社关系表:id, author_id, publish_id
  37. id author_id publish_id
  38. 1 1 1
  39. 2 1 2
  40. 3 2 1
  41. 4 2 2
  42. """

外键

  1. # 作者(author):id,name,sex,age,mobile, detail_id
  2. # 作者详情(author_detail): id,info,address
  3. # 1、外键的 字段名 可以自定义(名字随意),通常命名规范(关联表_关联字段)
  4. # 2、外键要通过 foreign key 语法建立表与表之间的关联
  5. # 3、foreign key(所在表的外键字段) references 关联表(关联字段)
  6. # eg:foreign key(detail_id) references author_detail(id)
  7. # 4、级联关系
  8. # 级联更新 on update cascade
  9. # 级联删除 on delete cascade
  10. # 重点:外键字段本身可以唯一或不唯一,但是外键关联的字段一定唯一

一对一:无级联关系

  1. # 作者详情(author_detail): id,info,address
  2. create table author_detail(
  3. id int primary key auto_increment,
  4. info varchar(256),
  5. address varchar(256)
  6. );
  7. # 作者表id,name,sex,age,mobile, detail_id
  8. create table author(
  9. id int primary key auto_increment,
  10. name varchar(64) not null,
  11. mobile char(11) unique not null,
  12. sex enum('男', '女') default '男',
  13. age int default 0,
  14. detail_id int unique not null,
  15. foreign key(detail_id) references author_detail(id)
  16. );
  17. # 必须先创建被关联表数据,有关联表外键关联的记录后,关联表才可以创建数据
  18. mysql>: insert into author_detail(info,address) values('Tom_info','Tom_address');
  19. mysql>: insert into author(name,mobile,detail_id) values('Tom','13344556677', 1);
  20. mysql>: insert into author_detail(info,address) values('Bob_info','Bob_address');
  21. mysql>: insert into author(name,mobile,detail_id) values('Bob','15666882233', 2);
  22. # 修改关联表 author
  23. mysql>: insert into author_detail(info,address) values('Tom_info_sup','Tom_address_sup');
  24. mysql>: update author set detail_id=3 where detail_id=2; # 有未被其他数据关联的数据,就可以修改
  25. # 删除关联表 author
  26. mysql>: delete from author where detail_id=3; # 直接删除
  27. # 修改被关联表 author_detail
  28. mysql>: update author_detail set id=10 where id=1; # 无法修改
  29. # 删除被关联表 author_detail
  30. mysql>: delete from author_detail where id=1; # 无法删除
  31. # 没有级联关系下:
  32. # 增加:先增加被关联表记录,再增加关联表记录
  33. # 删除:先删除关联表记录,再删除被关联表记录
  34. # 更新:关联与被关联表都无法完成 关联的外键和主键 数据更新 - (如果被关联表记录没有被绑定,可以修改)

一对一:有级联关系

  1. mysql>: drop table author;
  2. mysql>: drop table author_detail;
  3. # 作者详情(author_detail): id,info,address
  4. create table author_detail(
  5. id int primary key auto_increment,
  6. info varchar(256),
  7. address varchar(256)
  8. );
  9. # 作者表id,name,sex,age,mobile, detail_id
  10. create table author(
  11. id int primary key auto_increment,
  12. name varchar(64) not null,
  13. mobile char(11) unique not null,
  14. sex enum('男', '女') default '男',
  15. age int default 0,
  16. detail_id int unique not null,
  17. foreign key(detail_id) references author_detail(id)
  18. on update cascade
  19. on delete cascade
  20. );
  21. # 必须先创建被关联表数据,有关联表外键关联的记录后,关联表才可以创建数据
  22. mysql>: insert into author(name,mobile,detail_id) values('Tom','13344556677', 1); # 错误
  23. mysql>: insert into author_detail(info,address) values('Tom_info','Tom_address');
  24. mysql>: insert into author(name,mobile,detail_id) values('Tom','13344556677', 1);
  25. mysql>: insert into author_detail(info,address) values('Bob_info','Bob_address');
  26. mysql>: insert into author(name,mobile,detail_id) values('Bob','15666882233', 2);
  27. # 修改关联表 author
  28. mysql>: update author set detail_id=3 where detail_id=2; # 失败,3详情不存在
  29. mysql>: update author set detail_id=1 where detail_id=2; # 失败,1详情已被关联
  30. mysql>: insert into author_detail(info,address) values('Tom_info_sup','Tom_address_sup');
  31. mysql>: update author set detail_id=3 where detail_id=2; # 有未被其他数据关联的数据,就可以修改
  32. # 删除关联表 author
  33. mysql>: delete from author where detail_id=3; # 直接删除
  34. # 修改被关联表 author_detail
  35. mysql>: update author_detail set id=10 where id=1; # 级联修改,同步关系关联表外键
  36. # 删除被关联表 author_detail
  37. mysql>: delete from author where detail_id=10; # 可以删除对被关联表无影响
  38. mysql>: insert into author(name,mobile,detail_id) values('Tom','13344556677', 10);
  39. mysql>: delete from author_detail where id=10; # 可以删除,将关联表的记录级联删除掉

一对多

  1. # 一对多:外键必须放在多的一方,此时外键值不唯一
  2. # 出版社(publish): id,name,address,phone
  3. create table publish(
  4. id int primary key auto_increment,
  5. name varchar(64),
  6. address varchar(256),
  7. phone char(20)
  8. );
  9. # 书(book):id,name,price,publish_id, author_id
  10. create table book(
  11. id int primary key auto_increment,
  12. name varchar(64) not null,
  13. price decimal(5, 2) default 0,
  14. publish_id int, # 一对多的外键不能设置唯一
  15. foreign key(publish_id) references publish(id)
  16. on update cascade
  17. on delete cascade
  18. );
  19. # 增:先增加被关联表(publish)的数据,再增加关联表(book)的数据
  20. mysql>: insert into publish(name, address, phone) values
  21. ('人民出版社', '北京', '010-110'),
  22. ('西交大出版社', '西安', '010-119'),
  23. ('老男孩出版社', '上海', '010-120');
  24. mysql>: insert into book(name, price, publish_id) values
  25. ('西游记', 6.66, 1),
  26. ('东游记', 8.66, 1),
  27. ('python从入门到入土', 2.66, 2),
  28. ('轮程序员修养之道', 3.66, 3),
  29. ('好好活着', 88.88, 3);
  30. # 没有被关联的字段,插入依旧错误
  31. mysql>: insert into book(name, price, publish_id) values ('打脸之道', 0.3, 4); # 失败
  32. # 更新:直接更新被关联表的(publish) 主键,关联表(book) 外键 会级联更新
  33. mysql>: update publish set id=10 where id=1;
  34. # 更新:直接更新关联表的(book) 外键,修改的值对应被关联表(publish) 主键 如果存在,可以更新成功,反之失败
  35. mysql>: update book set publish_id=2 where id=4; # 成功
  36. mysql>: update book set publish_id=1 where id=4; # 失败
  37. # 删:
  38. # 删被关联表,关联表会被级联删除
  39. mysql>: delete from publish where id = 2;
  40. # 删关联表,被关联表不会发生变化
  41. mysql>: delete from book where publish_id = 3;
  1. # 假设:书与作者也是 一对多 关系,一个作者可以出版多本书
  2. create table book(
  3. id int primary key auto_increment,
  4. name varchar(64) not null,
  5. price decimal(5, 2) default 0,
  6. publish_id int, # 一对多的外键不能设置唯一
  7. foreign key(publish_id) references publish(id)
  8. on update cascade
  9. on delete cascade
  10. # 建立与作者 一对多 的外键关联
  11. author_id int,
  12. foreign key(author_id) references author(id)
  13. on update cascade
  14. on delete cascade
  15. );

多对多

  1. # 多对多:一定要创建第三张表(关系表),每一个外键值不唯一,看可以多个外键建立联合唯一
  2. mysql>: drop table author;
  3. mysql>: drop table author_detail;
  4. mysql>: drop table book;
  5. mysql>: drop table publish;
  6. # 作者(author):id, name, age
  7. create table author(
  8. id int primary key auto_increment,
  9. name varchar(64),
  10. age int unsigned default 0
  11. );
  12. # 出版社(publish):id, name, address
  13. create table publish(
  14. id int primary key auto_increment,
  15. name varchar(64),
  16. address varchar(256)
  17. );
  18. # 作者与出版社关系表:id, author_id, publish_id
  19. create table author_publish(
  20. id int primary key auto_increment,
  21. # 关系表一定有多个外键,关联着多张表
  22. # 关联作者表
  23. author_id int,
  24. foreign key(author_id) references author(id)
  25. on update cascade
  26. on delete cascade,
  27. # 关联出版社表
  28. publish_id int,
  29. foreign key(publish_id) references publish(id)
  30. on update cascade
  31. on delete cascade,
  32. # 建立两个字段的联合唯一
  33. unique(author_id, publish_id)
  34. );
  35. # 注:关系表 关联着 作者 和 出版社 两张表,在表结构上 作者 与 出版社 两表键没有任何关系
  36. # 增:两张被关联表,没有前后关系,但关系表必须在两个表都提供数据后才能进行 关系匹配
  37. mysql>: insert into author(name, age) values('ruakei', 67),('engo', 76),('Lxx', 3);
  38. mysql>: insert into publish(name, address) values('老男孩出版社', '上海'),('小女孩出版社', '北京');
  39. # 操作关系表:
  40. mysql>: insert into author_publish(author_id, publish_id) values(1,1),(1,2),(2,1),(2,2),(3,1);
  41. # 关系表操作:增、删、改,只要两张被关系表有提供对应的操作数据,都可以操作成功,且对两张被关系表没有影响
  42. # 操作两张被关系表:
  43. # 增:不会影响关系表
  44. mysql>: insert into publish(name, address) values('西交大出版社', '西安');
  45. # 改:关系表都会级联更新
  46. mysql>: update publish set id=10 where id=1;
  47. # 删:关系表都会级联删除
  48. mysql>: delete from author where name='ruakei'

MySQL数据库 字段操作 多表关系(更新中...)的更多相关文章

  1. Mysql数据库常规操作(建表、查询)

    一.表单操作 1-1.创建表 create table tb_name( id in primary key auto_increment);    1-2.查看表 desc table_name; ...

  2. mysql数据库为什么要分表和分区?

    一般下载的源码都带了MySQL数据库的,做个真正意义上的网站没数据库肯定不行. 数据库主要存放用户信息(注册用户名密码,分组,等级等),配置信息(管理权限配置,模板配置等),内容链接(html ,图片 ...

  3. Hibernate连接mysql数据库并自动创建表

    天才第一步,雀氏纸尿裤,Hibernate第一步,连接数据库. Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个 ...

  4. MySQL数据库性能优化:表、索引、SQL等

    一.MySQL 数据库性能优化之SQL优化 注:这篇文章是以 MySQL 为背景,很多内容同时适用于其他关系型数据库,需要有一些索引知识为基础 优化目标 减少 IO 次数IO永远是数据库最容易瓶颈的地 ...

  5. django 中连接mysql数据库的操作步骤

    django中连接mysql数据库的操作步骤: 1 settings配置文件中 DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mys ...

  6. DBA必备:MySQL数据库常用操作和技巧

    DBA必备:MySQL数据库常用操作和技巧 2011-02-25 15:31 kaduo it168 字号:T | T MySQL数据库可以说是DBA们最常见和常用的数据库之一,为了方便大家使用,老M ...

  7. Mysql数据库基础操作

    Mysql数据库基础操作 在mysql数据库中开启使用tab键补全功能 1)修改主配置文件/etc/mysql/my.cnf(mysql和mariadb目录有些不同) vim /etc/mysql/m ...

  8. MySQL 数据库高级操作 (配图)

    MySQL数据库高级操作 1.一键部署mysql 数据库 2.数据表高级操作 3.数据库用户管理 4.数据库用户授权 1.首先一键部署mysql 数据库 : 可以看我之前的博客 https://www ...

  9. zabbix数据库mariadb从服务器迁移到云mysql数据库的操作

    zabbix数据库mariadb从本机迁移到云mysql数据库的操作 1.将zabbix数据库导出,并导入到云数据库中 由于数据库较大,如果直接使用shell会话中断会导致数据库导出或者导入失败,使用 ...

随机推荐

  1. C++ 中vector数组的使用

    (1)头文件:#include<vector>.(2)创建vector对象: vector < 类型 > 名字;     例:vector<int> vec;(3) ...

  2. docker企业级镜像仓库harbor

    第一步:安装docker和docker-compose 第二步:下载harbor-offine-installer-v1.5.1.tgz 第三步:上传到/opt,并解压 第四步:修改harbor.cf ...

  3. Python编码decode和encode

    常见编码介绍: GB2312编码:适用于汉字处理.汉字通信等系统之间的信息交换;GBK编码:是汉字编码标准之一,是在 GB2312-80 标准基础上的内码扩展规范,使用了双字节编码ASCII编码:是对 ...

  4. Git log和reflog

    1.log  log命令可以显示所有提交过的版本信息.显示信息如下: Administrator@USER-20171026MG MINGW64 ~/Desktop/lyf (master) $ gi ...

  5. 9.1 mongo_python.py

    # 安装 pymongo pip install pymongo import pymongo try: # 1.链接mongod的服务 mongo_py = pymongo.MongoClient( ...

  6. JS规则 自加一,自减一 ( ++和- -) 【mynum = mynum + 1;//等同于mynum++;】

    自加一,自减一 ( ++和- -) 算术操作符除了(+.-.*./)外,还有两个非常常用的操作符,自加一"++":自减一"--".首先来看一个例子: mynum ...

  7. Linq学习笔记(第一部分)

    本文分享自lliulun的30分钟linq教程,地址:http://www.cnblogs.com/liulun/archive/2013/02/26/2909985.html 一:与LINQ有关的语 ...

  8. linux的mysql权限错误导致看不到mysql数据库

    1.首先停止mysql服务:service mysqld stop2.加参数启动mysql:/usr/bin/mysqld_safe --skip-grant-tables & 然后就可以无任 ...

  9. iOS7 断了统计和追踪用户的后路

    评论里大家都认可用identifierForVendor 然后用keychain和iCloud各保存一份. 看来这是接近最终结果的办法了. 官方文档又说了下面的话, 又有点费解. 我们只要把最后一组s ...

  10. Android基础控件ScrollView滚动条的使用

    1.简介 ScrollView是一个FrameLayout的容器,不过在他的基础上添加了滚动,允许显示的比实际多的内容!另外,只能够往里面放置一个子元素,可以是单一的组件,又或者一个布局包裹着的复杂的 ...