专业网站建设品牌,十四年专业建站经验,服务6000+客户--广州京杭网络
免费热线:400-683-0016      微信咨询  |  联系我们

如何创建外键_数据库

当前位置:网站建设 > 技术支持
资料来源:网络整理       时间:2023/3/5 20:39:59       共计:3578 浏览

如何创建外键?

主键

外键

索引

定义:

唯一标识一条记录,不能有重复的,不允许为空

表的外键是另一表的主键,外键可以有重复的,可以是空值

该字段没有重复值,但可以有一个空值

作用:

用来保证数据完整性

用来和其他表建立联系用的

是提高查询排序的速度

个数:

主键只能有一个

一个表可以有多个外键

一个表可以有多个惟一索引

设置索引

若要设置外键,在参照表(pc表)和被参照表(parts表)中,相对应的两个字段必须都设置索引(index)。

对parts表:

altertablepartsaddindexidx_model(model);

这句话的意思是,为parts表增加一个索引,索引建立在model字段上,给这个索引起个名字叫idx_model。

对pc表也类似:

altertablepcaddindexidx_cpumodel(cpumodel);

定义外键

下面为两张表之间建立前面所述的那种“约束”。因为pc的cpu型号必须参照parts表中的相应型号,所以我们将pc表的cpumodel字段设置为“外键”(foreignkey),即这个键的参照值来自于其他表。

altertablepcaddconstraintfk_cpu_model

foreignkey(cpumodel)

referencesparts(model);

级联操作

级联更新:更新主键时,外键也随之更新。

可以在定义外键的时候,在最后加入这样的关键字:

onupdatecascade;

即在主表更新时,子表(们)产生连锁更新动作,似乎有些人喜欢把这个叫“级联”操作。

如果把这语句完整的写出来,就是:

altertablepcaddconstraintfk_cpu_model

foreignkey(cpumodel)

referencesparts(model)

onupdatecascade;

级联删除:删除主键时,外键也随之删除。

altertablepcaddconstraintfk_cpu_model

foreignkey(cpumodel)

referencesparts(model)

ondeletecascade;

级联更新、删除:

onupdatecascadeondeletecascade

版权说明:
本网站凡注明“广州京杭 原创”的皆为本站原创文章,如需转载请注明出处!
本网转载皆注明出处,遵循行业规范,如发现作品内容版权或其它问题的,请与我们联系处理!
欢迎扫描右侧微信二维码与我们联系。
·上一条:列族数据库存储原理_数据库 | ·下一条:mysql查询存储过程,redis是否可以代替mysql进行数据存储_数据库

Copyright © 广州京杭网络科技有限公司 2005-2024 版权所有    粤ICP备16019765号 

广州京杭网络科技有限公司 版权所有