mysql中外键如何使用?

mysql中外键如何使用?,第1张

1、只有InnoDB类型的表才可以使用外键。mysql默认是MyISAM,这种类型不支持外键约束

2、外键的好处:可以使得两张表关联,保证数据的一致性和实现一些级联 *** 作。

3、外键的作用:

保持数据一致性,完整性,主要目的是控制存储在外键表中的数据。 使两张表形成关联,外键只能引用外表中的列的值。

4、建立外键的前提:

两个表必须是InnoDB表类型。

使用在外键关系的域必须为索引型(Index)。

使用在外键关系的域必须与数据类型相似。

5、创建的步骤

指定主键关键字: foreign key(列名)。

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

6、事件触发限制:on delete和on update , 可设参数cascade(跟随外键改动)。

restrict(限制外表中的外键改动),set

Null(设空值),set Default(设默认值)。

[默认]no action

7、举例

outTable表 主键 id 类型 int

创建含有外键的表:

代码如下:

create table temp(

id int,

name

char(20),

foreign key(id) references outTable(id) on delete cascade on update

cascade)

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

代码如下:

create table temp( id int, name char(20),

foreign key(id) references outTable(id) on delete cascade on update

cascade)

a

b

c

这3张表在设计的时候就应该是把主键和外键设好的吧,所以这和插入数据时所使用的语句是没有什么关系的,

而数据的对应关系就是这样的吧

A--〉a

B--〉b,

C--〉c

a,b,c

表只多了个时间字段,那你给这个字段设默认值的时候设为

getdate()就可以了

不用人为的去插入时间了~

用简单的SQL就可以了

比如

SELECT

*

INTO

a

FROM

A


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/7148489.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-02
下一篇 2023-04-02

发表评论

登录后才能评论

评论列表(0条)

保存