本文摘自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索引背后的数据结构及算法原理详解
认识什么是锁,mysql中锁如何解决幻读问题
mysql导入数据库的方法
mysql 简单全量备份和快速恢复的方法
mysql 动态生成测试数据
mysql分页性能探索
在linux系统安装mysql步骤截图详解
mysql的sql删除列语句是什么
mysql安全策略分享
如何理解spring事务及声明式事务的使用
更多相关阅读请进入《mysql》频道 >>
机械工业出版社
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。
转载请注明出处:木庄网络博客 » mysql外键约束怎么创建