本文摘自PHP中文网,作者V,侵删。
我们可以在创建表时设置外键约束。
在 CREATE TABLE 语句中,通过 FOREIGN KEY 关键字来指定外键,具体的语法格式如下:
1 2 | [ CONSTRAINT <外键名>] FOREIGN KEY 字段名 [,字段名2,…]
REFERENCES <主表名> 主键列1 [,主键列2,…]
|
举例:
现在在 test_db 数据库中创建一个部门表 tb_dept1,表结构如下图所示:
创建 tb_dept1 的 SQL 语句和运行结果如下所示。
1 2 3 4 5 6 7 | mysql> CREATE TABLE tb_dept1
-> (
-> id INT (11) PRIMARY KEY ,
-> name VARCHAR (22) NOT NULL ,
-> location VARCHAR (50)
-> );
Query OK, 0 rows affected (0.37 sec)
|
创建数据表 tb_emp6,并在表 tb_emp6 上创建外键约束,让它的键 deptId 作为外键关联到表 tb_dept1 的主键 id,SQL 语句和运行结果如下所示。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | mysql> CREATE TABLE tb_emp6
-> (
-> id INT (11) PRIMARY KEY ,
-> name VARCHAR (25),
-> deptId INT (11),
-> salary FLOAT ,
-> CONSTRAINT fk_emp_dept1
-> FOREIGN KEY (deptId) REFERENCES tb_dept1(id)
-> );
Query OK, 0 rows affected (0.37 sec)
mysql> DESC tb_emp6;
+
| Field | Type | Null | Key | Default | Extra |
+
| id | int (11) | NO | PRI | NULL | |
| name | varchar (25) | YES | | NULL | |
| deptId | int (11) | YES | MUL | NULL | |
| salary | float | YES | | NULL | |
+
4 rows in set (1.33 sec)
|
以上语句执行成功之后,在表 tb_emp6 上添加了名称为 fk_emp_dept1 的外键约束,外键名称为 deptId,其依赖于表 tb_dept1 的主键 id。
注意:从表的外键关联的必须是主表的主键,且主键和外键的数据类型必须一致。例如,两者都是 INT 类型,或者都是 CHAR 类型。如果不满足这样的要求,在创建从表时,就会出现“ERROR 1005(HY000): Can't create table”错误。
推荐教程:mysql教程
以上就是mysql外键约束怎么创建的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
mysql数据库是如何实现xa规范的
mysql查询最大值语句是什么
浅谈mysql大表优化方案
mysql中delete from where子查询的限制介绍
对mysql锁、事务、mvcc的简单认识
docker安装mysql8的方法步骤
利用mysql实现的雪花算法案例
mysql使用中遇到的问题记录
mysql官网如何下载源码包?
mysql数据库基础篇sql窗口函数示例解析教程
更多相关阅读请进入《mysql》频道 >>
机械工业出版社
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。
转载请注明出处:木庄网络博客 » mysql外键约束怎么创建