我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Navicat如何添加外键

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Navicat如何添加外键

小编给大家分享一下Navicat如何添加外键,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

正文

想要建立class表与student表之间的外键连接,class为父表,student为子表

Navicat如何添加外键

Navicat如何添加外键

打开student的设计表。

Navicat如何添加外键

Navicat如何添加外键

如果c_id不允许为空则当,选择删除时-->>SET NULL就会出现Cannot add foreign key constraint的提示,这是因为删除置空有条件,必须满足字段允许为空(如果不满足,外键无法创建)当然,如果不允许为空,可以选择删除时-->>CASCADE也可以建立外键。

Navicat如何添加外键

当勾选允许为空之后

Navicat如何添加外键

再去保存就可以了。

还有必须注意,Engin必须为InnoDB。

Navicat如何添加外键

总结一下:

外键条件

在我们使用外键的时候,应该遵循如下条件:

  • 外键要存在,首先必须保证表的引擎是 InnoDB(默认的存储引擎),如果不是 InnoDB 存储引擎,那么外键可以创建成功,但没有约束作用;

  • 外键字段的字段类型(列类型),必须与父表的主键类型完全一致;

  • 每张表中的外键名称不能重复;

  • 增加外键的字段,如果数据已经存在,那么要保证数据与父表中的主键对应。

  • 如果外键约束模式选择SET NULL ,那么字段必须允许为NULL,否则出现Cannot add foreign key constraint。

外键约束

所谓外键约束,就是指外键的作用。之前所讲的外键的作用都是默认的作用,实际上,可以通过对外键的需求,进行定制操作。

外键约束有三种模式,分别为:

  • district:严格模式(默认),父表不能删除或更新一个已经被子表数据引用的记录;

  • cascade:级联模式,父表的操作,对应子表关联的数据也跟着被删除;

  • set null:置空模式,父表的操作之后,子表对应的数据(外键字段)被置空。

 设计外键的界面,有七列:

  • 名(name):可以不填,保存时会自动生成。

  • 栏位(FieldName):要设置的外键,如:student 里的c_id

  • 参考数据库(Reference DataBase):外键关联的数据库

  • 被参考表(Reference Table):关联的表,这里是class表

  • 参考栏位(Forgin filed Names):关联的字段,class里的id

  • 删除时(ondelete):删除时候的动作,当时我选择的是SETNULL

  • 更新时(onupdate):更新时候的动作,我选择的是CASCADE

以上字段也可以按照自己的需求填写,设置完成后保存即可。

某个表已经有记录了,添加外键失败,这时候只需要将两个要关联的表中的数据清空再从新添加外键关系即可。

看完了这篇文章,相信你对“Navicat如何添加外键”有了一定的了解,如果想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Navicat如何添加外键

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

navicat模型中如何添加外键

在 navicat 中添加外键的步骤:选择外键列,并在 "外键" 选项卡中指定引用表、参照字段。设置删除和更新操作:cascade、set null、set default 或 restrict。单击 "确定" 保存更改,navicat 将
navicat模型中如何添加外键
2024-04-24

navicat如何添加外键约束命令

在 navicat 中使用 sql 命令添加外键约束可确保数据的一致性:命令结构:alter table child_table add foreign key (child_column) references parent_table
navicat如何添加外键约束命令
2024-04-24

windows中navicat怎么添加外键

这篇文章主要介绍“windows中navicat怎么添加外键”,在日常操作中,相信很多人在windows中navicat怎么添加外键问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”windows中navicat
2022-12-03

mysql如何添加外键

在 mysql 中添加外键可确保数据完整性,通过将一个表中的列与另一个表中的主键关联实现。在表中添加外键的语法为:alter table table_name add foreign key (column_name) references
mysql如何添加外键
2024-06-15

mysql如何添加外键约束

要在MySQL数据库中添加外键约束,可以使用以下步骤:在创建表时定义外键约束:CREATE TABLE 表名 (列名 数据类型,...FOREIGN KEY (外键列名) REFERENCES 关联表名(关联列名));例如:CREAT
mysql如何添加外键约束
2024-04-09

sqlserver如何添加外键约束

在SQL Server中,可以使用ALTER TABLE语句来添加外键约束。以下是添加外键约束的语法:```sqlALTER TABLE 子表名ADD CONSTRAINT 约束名FOREIGN KEY (子表外键列名) REFERENCE
2023-09-26

PostgreSQL中如何添加外键约束

要在PostgreSQL中添加外键约束,可以按照以下步骤操作:1、首先,在创建表时,确保在需要添加外键约束的列上定义约束,如下所示:CREATE TABLE table1 (id SERIAL PRIMARY KEY,column1 V
PostgreSQL中如何添加外键约束
2024-04-09

sql如何给表添加外键约束

要给表添加外键约束,需要使用ALTER TABLE语句来修改表结构。下面是一个示例:ALTER TABLE 表名ADD CONSTRAINT 外键约束名FOREIGN KEY (外键列名) REFERENCES 关联表名(关联列名);
sql如何给表添加外键约束
2024-04-20

mysql添加外键失败如何解决

这篇文章主要讲解了“mysql添加外键失败如何解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql添加外键失败如何解决”吧!mysql添加外键失败的解决
2023-02-22

mysql添加不了外键如何解决

MySQL添加外键失败的原因可能有以下几种:1. 父表和子表的数据类型不一致:父表外键字段的数据类型必须和子表的被引用字段的数据类型一致。如果不一致,需要确保数据类型一致后再添加外键。2. 父表和子表的字符集不一致:父表外键字段的字符集必须
2023-08-30

navicat如何添加字段

在 navicat 中添加字段的操作步骤如下:选择表并进入表设计器。单击 "+字段" 按钮添加新字段。定义字段属性,包括字段名、数据类型、长度、默认值等。根据需要设置主键或外键约束。单击 "保存" 按钮保存更改。如何在 Navicat 中添
navicat如何添加字段
2024-04-23

mysql如何为字段添加外键约束

要为字段添加外键约束,需要执行以下步骤:1、创建两个表,其中一个表将包含外键,另一个表将包含主键。例如,我们创建一个名为table1的表,该表将包含外键,以及一个名为table2的表,该表将包含主键。CREATE TABLE table
mysql如何为字段添加外键约束
2024-04-22

navicat如何设置主键与外键

navicat 设置主键和外键:主键:选择表中唯一标识每行的列,右键单击并选择“设置主键”。外键:选择要创建外键的列,右键单击并选择“修改列”,选中“外键”复选框,选择外键关联的表和列。详细信息:主键防止数据重复,确保数据完整性。外键建立表
navicat如何设置主键与外键
2024-04-24

编程热搜

目录