当前第2页 返回上一页
为了展现表与表之间的外键关系,本例在 test_db 数据库中创建一个部门表 tb_dept1,表结构如下表所示。
字段名称 | 数据类型 | 备注 |
---|
id | INT(11) | 部门编号 |
name | VARCHAR(22) | 部门名称 |
location | VARCHAR(22) | 部门位置 |
创建 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中concat以及group_concat的使用
mysql日志文件有什么用
mysql 数据类型和建库策略
mysql和navicat什么关系
忘记mysql密码了!?莫慌~
mysql配置文件my.ini全过程
mysql中关于表数据文件损坏导致数据库无法启动的问题解决
更多相关阅读请进入《mysql》频道 >>
机械工业出版社
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。
转载请注明出处:木庄网络博客 » mysql建表外键怎么设?