您的位置:

mysql数据库如何建立外键,mysql 创建外键

mysql数据库如何建立外键,mysql 创建外键

更新:

本文目录一览:

mysql怎么定义外键

数据库mysql

建立外键的前提:本表的列必须与外键类型相同(外键必须是外表主键)。

外键作用:使两张表形成关联,外键只能引用外表中的列的值!

指定主键关键字:foreignkey(列名)

引用外键关键字:references外键表名(外键列名)

事件触发限制:ondelete和onupdate,可设参数cascade(跟随外键改动),restrict(限制外表中的外键改动),setNull(设空值),setDefault(设默认值),[默认]noaction

例如:

outTable表主键id类型int

创建含有外键的表:

createtabletemp(

idint,

namechar(20),

foreignkey(id)referencesoutTable(id)ondeletecascadeonupdatecascade);

说明:把id列设为外键参照外表outTable的id列当外键的值删除本表中对应的列筛除当外键的值改变本表中对应的列值改变。

自己实践才能完全了解外键的作用关键是:事件触发限制的作用

mysql数据库如何添加外键

mysql增加外键的方法:1、在CREATE TABLE语句中,通过FOREIGN KEY关键字来添加外键;2、在ALTER TABLE语句中,通过ADD和FOREIGN KEY关键字来添加外键。

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怎么设定外键

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

语法: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中如何设置主键和外键

工具/原料

电脑   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数据库如何建立外键,mysql 创建外键

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

2023-12-08
mysql数据库id外键(MySQL外键)

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

2022-11-19
数据库mysql表怎么设置外键,数据库表如何设置外键

2022-11-20
mysql数据库番外篇之(MySQL数据库笔记)

2022-11-16
mysql如何建立自己数据库,mysql如何建立自己数据库

2022-11-21
数据库怎么加外键,数据库怎么加外键和内键

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

2022-11-14
mysql数据库外键约束,mysql添加外键约束的两种方式重

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

2022-11-20
利用mysql创建一个数据库(如何创建一个mysql数据库?

2022-11-16
如何用mysql建立一个数据库(如何用mysql建立一个数据

2022-11-12
在服务器创建mysql数据库(MYSQL创建数据库)

2022-11-13
用mysql5创建一个数据库(mysql 创建数据)

2022-11-14
如何创建MySQL数据库

2023-05-11
和mysql新建数据库(mysql创建数据库)

2022-11-15
mysql主键索引创建的实例,mysql创建主键索引语法

2022-11-20
mysql中如何建立数据库,mysql中怎么创建数据库

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

2022-11-13
我们数据库自建的mysql(数据库创建库)

2022-11-08