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

mysql查询排除空值,sql中key用法有哪些_数据库

当前位置:网站建设 > 技术支持
资料来源:网络整理       时间:2023/3/5 16:20:26       共计:3614 浏览
mysql查询排除空值,sql中key用法有哪些?MySQL中外键(FROEIGN KEY)的使用

1.定义:

外键用来在两个表的数据之间建立链接,它可以是一列或者多列;一个表可以有一个或多个外键。

外键对应的是参照完整性,一个表的外键可以为空值,若不为空值,则每一个外键值必须等于另一个表中主键的某个值。

外键是表的一个字段,不是表的主键,但对应另一个表的主键;定义外键后,不允许删除另一个表中具有关联关系的行。

主表(父表):对于两个具有关联关系的表而言,相关联字段中主键所在的那个表即是主表;

从表(子表):对于两个具有关联关系的表而言,相关联字段中外键所在的那个表即是从表。

被指向的实体,称之为主实体(主表),也叫父实体(父表)

负责指向的实体,称之为从实体(从表),也叫子实体(子表);

?

若‘表1’的一个列既是主键又是外键,而这个外键约束又对应另一个表‘表2’的主键,那么‘表1’和‘表2’就可以合并起来了

2.作用:

外键的主要作用是保持数据的一致性、完整性。

如果主表没有相关的记录,从表不能插入;

更新时,不能改为主键表中没有的值;

删除主键表记录时,可以在建外键时选定外键记录一起级联删除还是拒绝删除;同样有级联更新和拒绝更新的选择。

ON DELETE CASCADE 级联删除

ON UPDATE CASCADE 级联更新

3.设置MySQL外键约束字段的规则:

? 父表必须已经存在于数据库中,或者是当前正在创建的表;若是后者,则父表与子表是同一个表,这样的表称为自参照完整性。

? 必须为父键定义主键。

? 主键不能包含空值,但允许在外键中出现空值;也就是说,只要外键的每个非空值出现在指定的主键中,这个外键的内容就是正确的。

? 在父表的表名后面指定列名或列名的组合,这个列的组合必须是父键的主键或者候选键。

? 外键中列的数据类型和父键主键中对应的数据类型相同。

? 外键中列的数目必须和父键中列的数目相同。

4.创建、添加外键的语法规则:

(1) 创建

[CONSTRAINT ] FOREIGN KEY 字段名 [,字段名2,…]

REFERENCES 主键列1 [,主键列2,…]

“外键名”为定义的外键约束的名称,一个表中不能有相同名称的外键;

“字段名”表示子表需要添加外键约束的字段列;

“主表名”即被子表外键所依赖的表的名称;

“主键列”表示主表中定义的主键列,或者列组合。

(2) 添加

ALTER TABLE ADD CONSTRAINT (形如:FK_从表_主表)

FOREIGN KEY () REFERENCES ();

版权说明:
本网站凡注明“广州京杭 原创”的皆为本站原创文章,如需转载请注明出处!
本网转载皆注明出处,遵循行业规范,如发现作品内容版权或其它问题的,请与我们联系处理!
欢迎扫描右侧微信二维码与我们联系。
·上一条:mysql全模糊查询优化,MySQL数据库在索引条件相同的情况下_数据库 | ·下一条:mysql慢查询解决办法,对MySQL慢查询日志进行分析的基本教程_数据库

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

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