MySQL入门(三)

字段的修改、添加、与删除

修改表字段使用alter table语句,谨记!

create table tf1(
id int primary key auto_increment,
x int,
y int
); # 修改
alter table tf1 modify x char(4) default '';
alter table tf1 change y m char(4) default ''; # 增加
mysql>: alter table 表名 add 字段名 类型[(长度) 约束]; # 末尾
eg>: alter table tf1 add z int unsigned; mysql>: alter table 表名 add 字段名 类型[(宽度) 约束] first; # 首位
eg>: alter table tf1 add a int unsigned first; mysql>: alter table 表名 add 字段名 类型[(宽度) 约束] after 旧字段名; # 某字段后
eg>: alter table tf1 add xx int unsigned after x; mysql>: alter table 表名 drop 字段名; # 删除字段
eg>: alter table tf1 drop a;

多表关系(外键)

外键基础知识

"""
多表关系主要如下:
一对一:外键在任何一方都可以,此时外键要设置 唯一键
一对多:外键必须放在多的一方,此时外键值不唯一
多对多:一定要创建第三张表(关系表),每一个外键值不唯一,看可以多个外键建立联合唯一
"""
# 1、外键的 字段名 可以自定义(名字随意),通常命名规范(关联表_关联字段) # 2、外键要通过 foreign key 语法建立表与表之间的关联 # 3、[constraint 外键名 ]foreign key(所在表的外键字段) references 关联表(关联字段)
# eg:foreign key(detail_id) references author_detail(id) # 4、级联关系
# 级联更新 on update cascade
# 级联删除 on delete cascade # 重点:外键字段本身可以唯一或不唯一,但是外键关联的字段一定唯一 """
非级联的两张关系表,若数据已经被从表引用,则主表的那条数据无法更新或删除,只有先删了从表的数据才能操作主表的数据;
有级联的两张关系表,主表的数据更新或删除,会同时影响从表,会跟着一起更新或删除。
""" """
了解内容:(除级联外的其他reference_option)
set null:从父表中删除或更新该行,并将子表中的一个或多个外键列设置为NULL。ON DELETE SET NULLON UPDATE SET NULL。 restrict:拒绝父表的删除或更新操作。指定 RESTRICT(或NO ACTION)与省略ON DELETEor ON UPDATE子句相同。 no action :标准SQL中的关键字。在MySQL中等效于RESTRICT。 set default:
"""

设置外键

# 建表语句
CREATE TABLE parent (
id INT NOT NULL,
PRIMARY KEY (id)
) ENGINE=INNODB; CREATE TABLE child (
id INT,
parent_id INT,
INDEX par_ind (parent_id),
FOREIGN KEY (parent_id)
REFERENCES parent(id)
ON DELETE CASCADE
); # 升级版 product_order表具有其他两个表的外键。一个引用product的两个字段,一个引用customer的一列:
CREATE TABLE product (
category INT NOT NULL, id INT NOT NULL,
price DECIMAL,
PRIMARY KEY(category, id)
) ENGINE=INNODB; CREATE TABLE customer (
id INT NOT NULL,
PRIMARY KEY (id)
) ENGINE=INNODB; CREATE TABLE product_order (
no INT NOT NULL AUTO_INCREMENT,
product_category INT NOT NULL,
product_id INT NOT NULL,
customer_id INT NOT NULL, PRIMARY KEY(no),
INDEX (product_category, product_id),
INDEX (customer_id), FOREIGN KEY (product_category, product_id)
REFERENCES product(category, id)
ON UPDATE CASCADE ON DELETE RESTRICT, FOREIGN KEY (customer_id)
REFERENCES customer(id)
) ENGINE=INNODB;

添加外键

如果我们忘记设置外键也可以后续添加(如果没有那个字段就需要先手动添加):

ALTER TABLE tbl_name
ADD [CONSTRAINT [symbol]] FOREIGN KEY
[index_name] (col_name, ...)
REFERENCES tbl_name (col_name,...)
[ON DELETE reference_option]
[ON UPDATE reference_option]

删除外键

我们可以使用alter table语法来删除外键:

ALTER TABLE tbl_name DROP FOREIGN KEY fk_symbol;

若是不知道外键名称可以使用show create table语法来查看:

最新文章

  1. WinForm------DateEdit属性设置
  2. 从零开始学Python08作业思路:开发简单的FTP
  3. union内嵌struct用法
  4. Go http共享
  5. 在虚机中安装CentOS
  6. 【python】Head First Python(五)
  7. Objective-C 学习笔记(Day 3,上)
  8. Java中IO流
  9. POJ3268Dijkstra
  10. Pandas截取列部分字符,并据此修改另一列的数据
  11. Beta冲刺三
  12. Java——this关键字
  13. 离线安装IDEA插件
  14. kafka性能测试1.0.0
  15. 导出函数__declspec(dllexport)
  16. JavaScript -- FileSystemObject-文件
  17. 学习Git操作的好资源
  18. vue.js(一)
  19. NOI2019省选模拟赛 第六场
  20. Vue2.5入门-1

热门文章

  1. RocketMQ系列(四)顺序消费
  2. Springboot搭建Eureka并设置Eureka登录账号密码
  3. Vue —— 精讲 VueRouter(1)
  4. 基于Python3.7的robotframework环境搭建步骤
  5. Django自定义500的错误显示信息
  6. java递归遍历树结构目录
  7. 获取系统的IP地址
  8. Python3使用cookielib模块
  9. 3、尚硅谷_SSM高级整合_使用ajax操作实现修改员工的功能
  10. 动力节点 mysql 郭鑫 34道经典的面试题三