您的位置:

数据库mysql表怎么设置外键,数据库表如何设置外键

本文目录一览:

在MySQL中如何设置主键和外键

工具/原料

电脑   MySQL

方法/步骤

设置主键:

1、通过终端进入到mysql命令行工具。

2、通过use关键字进行到目标数据库里。

3、如原表已有主键,先把原来的主键删除掉,通过DROP PRIMARY KEY命令:ALTER TABLE `jingyan` DROP PRIMARY KEY;。

4、主键已经没有了。

5、通过命令:ADD PRIMARY KEY来添加ALTER TABLE `jingyan` ADD PRIMARY KEY ( `id` ) 。

6、输入后按下回车键即可看到 query ok执行成功的字符。

7、回到数据库的可视化工具,即可显示现在的表在id列上添加了主键了。

设置外键:

1、创建好主从表。

2、选择主表,点击设计表,进入到表设计界面。

3、点击外键,进入到外键设置界面。

4、先设置外键名称和选择主表的外键字段。

5、然后在设置外键字段对应从表的数据库、表名和字。

6、点击保存就完成外键设置了。

mysql表创建好后添加外键

首先要创建一个字段:alter table 表名 add 字段名 字段类型;

再添加外键约束:alter table 需加外键的表 add constraint 外键名 foreign key(需加外键表的字段名) references 关联表名(关联字段名);

注意:外键名不能重复

mysql怎么设定外键

为已经添加好的数据表添加外键:

语法:alter table 表名 add constraint FK_ID foreign key(你的外键字段名) REFERENCES 外表表名(对应的表的主键字段名);

例: alter table tb_active add constraint FK_ID foreign key(user_id) REFERENCES tb_user(id)

//FK_ID是外键的名称

/*

CREATE TABLE `tb_active` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`title` varchar(100) CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL,

`content` text CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL,

`user_id` int(11) NOT NULL,

PRIMARY KEY (`id`),

KEY `user_id` (`user_id`),

KEY `user_id_2` (`user_id`),

CONSTRAINT `FK_ID` FOREIGN KEY (`user_id`) REFERENCES `tb_user` (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=latin1

*/

删除外键

语法: ALTER TABLE table-name DROP FOREIGN KEY key-id;

例: ALTER TABLE `tb_active` DROP FOREIGN KEY 'FK_ID'

自动键更新和删除:

外键可以保证新插入的记录的完整性,但是,如果在REFERENCES从句中已命名的表删除记录会怎么样?在使用同样的值作为外键的辅助表中会发生什么?

很明显,那些记录也应该被删除,否则在数据库中就会有很多无意义的孤立记录,MYSQL可以通过向FOREIGN KEY...REFERENCES修饰符添加一个ON DELETE 或ON UPDATE子句简化任务,它告诉了数据库在这种情况如何处理孤立任务。

mysql建立外键时,多对多如何建立?

一张表中的主键只能有一个,外键可以有多个,如果一张表中多个列都需要被别的表的外键参考,需要使用候选码(非空并且唯一),具体到你的这个问题的需求可以考虑用如下方法解决:

把a表中的bookid和authorid都设置为非空并且唯一,即

create table a(bookid int not null unique, authorid int not null unique);

然后在book表和author表中就可以分别设置外键来参照a表中两个不同的字段了。

打开我的navicat,然后找到我的teacher表,选中它,然后点击菜单栏上的‘design table'

2. 在弹出的对话框中找到“Foreign Keys”,然后单机。

3. 然后会出现一个设置外键的界面,一共有七列。简单介绍一下这几列的意思。‘name’:可以不填,你一会保存成功系统会自动生成。FieldName’:就是你要把哪个键设置为外键。这里选择‘dept’,‘Reference DadaBase’:外键关联的数据库。‘Reference Table‘ :关联的表 这里是dept表‘Forgin filed Names’:关联的的字段,这里是code‘ondelete’:就是删除的时候选择的动作。这里我的选择是setNull,意思就是当关联的表删除以后,teacher》dept字段会设置为null.

4. 设置完成后点击‘save’保存退出,也可以点击‘add Foreign Key’再添加一个外键。

打开我的navicat,然后找到我的teacher表,选中它,然后点击菜单栏上的‘design table’。如下图:

2. 在弹出的对话框中找到“Foreign Keys”,然后单机。如下图:

3. 然后会出现一个设置外键的界面,一共有七列。简单介绍一下这几列的意思。‘name’:可以不填,你一会保存成功系统会自动生成。FieldName’:就是你要把哪个键设置为外键。这里选择‘dept’,‘Reference DadaBase’:外键关联的数据库。‘Reference Table‘ :关联的表 这里是dept表‘Forgin filed Names’:关联的的字段,这里是code‘ondelete’:就是删除的时候选择的动作。这里我的选择是setNull,意思就是当关联的表删除以后,teacher》dept字段会设置为null。如图

4. 设置完成后点击‘save’保存退出,也可以点击‘add Foreign Key’再添加一个外键。k如图:

数据库mysql表怎么设置外键,数据库表如何设置外键

2022-11-20
数据库mysql设置外键的语句(mysql数据库外键怎么设置

2022-11-14
mysql数据库id外键(MySQL外键)

2022-11-15
mysql数据库如何建立外键,mysql 创建外键

本文目录一览: 1、mysql怎么定义外键 2、mysql数据库如何添加外键 3、mysql建立外键时,多对多如何建立? 4、mysql怎么设定外键 5、在MySQL中如何设置主键和外键 mysql怎

2023-12-08
数据库怎么加外键,数据库怎么加外键和内键

2022-12-01
mysql数据库番外篇之(MySQL数据库笔记)

2022-11-16
mysql数据库中使用外键约束,数据库添加外键约束

2022-11-20
mysql数据库优化参数设置(mysql数据库优化参数设置在

2022-11-09
mysql数据库中间表如何设计,mysql数据库表的设计

2022-11-18
mysql数据库怎么设置自增(mysql数据库建表自增)

2022-11-10
mysql数据库完整笔记(mysql数据库数据)

2022-11-13
mysql数据库表用什么做主键(数据库中表的主键)

2022-11-14
mysql数据库必须设置主键吗(mysql必须要有主键吗)

2022-11-12
如何为mysql数据库设置密码(MySQL数据库设置密码)

2022-11-10
mysql查看数据库参数设置(mysql设置参数查询sql语

2022-11-12
mysql数据库怎么设置密码(mysql数据库怎么设置密码保

2022-11-10
修改mysql数据库参数(mysql数据库参数设置和调整)

2022-11-15
mysql创建数据库主键,mysql如何创建主键

2022-11-19
mysql数据库设置权限表(mysql 数据库权限)

2022-11-15
数据库的笔记mysql,数据库管理系统笔记

2022-11-24