数据库外键表示了两个关系之间的相关联系。以另一个关系的外键作主关键字的表被称为主表,具有此外键的表被称为主表的从表。下面我们就为大家介绍一下navicat如何创建外键。
推荐教程:MySQL入门视频教程
1、打开navicat选择要操作的数据库表,右键选择设计表。
2、点击外键选项就可以开始设置外键了。
一共有七列。简单介绍一下这几列的意思:
“名”: 可以不填,你一会保存成功系统会自动生成。
“栏位”:就是你要把哪个键设置为外键。
“参考数据库”: 外键关联的数据库。
“参考表”: 关联的表
“参考栏位”:关联的的字段,
“删除时":就是删除的时候选择的动作。
“ 更新时”:就是更新的时候选择的动作。
扩展资料:外键的作用
保持数据一致性,完整性,主要目的是控制存储在外键表中的数据。 使两张表形成关联,外键只能引用外表中的列的值或使用空值。
如果不使用外键,表2的学号字段插了一个值(比如20140999999),但是这个值在表1中并没有,这个时候,数据库允许插入,并不会对插入的数据做关系检查。然而在设置外键的情况下,你插入表2学号字段的值必须要求在表1的学号字段能找到。 同时,如果你要删除表1的某个学号字段,必须保证表2中没有引用该字段值的列,否则就没法删除。这就是所谓的保持数据的一致性和完整性。如右图,如果表2还引用表1的某个学号,你却把表1中的这个学号删了,表2就不知道这个学号对应的学生是哪个学生。
数据库中的表必须符合规范,才能杜绝数据冗余、插入异常、删除异常等现象。规范的过程是分解表的过程。经过分解,伺一事物的代表属性出现在不同的表中。显然,它们应该保持一致。例如,某学生的代表数据是学号012,在学生表里是012,在成绩表里也应该是012。这种一致性由外键实现。外键的功能是:它的值一定是另一个表的主键值。学号在学生表里是主键,在成绩表里是外键。成绩表里的学号一定要是学生表里的学号。于是,学生表里的学号和成绩表里的学号就一致了。可以直观地理解,外键的功能是实现同一事物在不同表中的标志一致性。2功能的实现由外键联系的两个表,在单独操作时,外键功能由两种方法实现 [4] :
阻止执行
●从表插入新行,其外键值不是主表的主键值便阻止插入;
●从表修改外键值,新值不是主表的主键值便阻止修改;
●主表删除行,其主键值在从表里存在便阻止删除(要想删除,必须先删除从表的相关行);
●主表修改主键值,旧值在从表里存在便阻止修改(要想修改,必须先删除从表的相关行)。
级联执行
●主表删除行,连带从表的相关行一起删除;
●主表修改主键值,连带从表相关行的外键值一起修改。两种方法提供给用户选择。无论选取哪种方法,从表里都不会有多余行。从另一个角度理解,用拒绝同一事物在从表中的标志与主表不一致来实现与主表中的标志一致。
●两种实现方法,通过下面方式选择:
●界面:设级联更新、级联删除两个选择方框,选取则级联执行、不选取则阻止执行;
●命令:设E)kSCM)E、RESTRICT两个可选项,CASCADE为级联执行、RESTRICT为阻止执行。
以上是navicat怎么建立外键的详细内容。更多信息请关注PHP中文网其他相关文章!

Navicat支持多种数据库,如MySQL、PostgreSQL、Oracle,并提供数据迁移、SQL开发等功能。1.连接源数据库(如MySQL)。2.连接目标数据库(如PostgreSQL)。3.选择要迁移的表和数据。4.执行迁移操作。

选择数据库管理工具的步骤包括:1.了解DBMS的定义和功能,2.评估工具的工作原理和查询优化器性能,3.掌握基本和高级用法,4.识别并解决常见错误,5.关注性能优化和最佳实践。通过这些步骤,你可以根据项目需求找到最合适的数据库管理工具,确保数据管理的高效和安全。

Navicat根据不同数据库系统提供灵活的定价方案,用户可根据需求选择合适版本。1.NavicatforMySQL有标准版($199)、企业版($499)和教育版($99)。2.NavicatPremium支持多数据库,标准版$499,企业版$999,适合中大型企业。

Navicat是否物超所值?这取决于你的需求和预算。如果你经常处理复杂数据库任务且预算充足,Navicat值得投资;但如果只是偶尔管理数据库或预算有限,可能有更适合的选择。

Navicat的成本主要受版本选择、订阅模式、数据库支持和附加功能的影响。1.个人版适合单个开发者或小型项目,价格较低。2.团队版和企业版提供更多功能,价格较高,适用于团队协作和大型企业。3.订阅模式提供持续更新和支持,但长期成本可能高于永久许可证。

Navicat不是免费的,但提供14天的试用版,试用期满后需购买许可证。Navicat有多种定价计划:1.个人版适合个人开发者和小型团队;2.企业版适合大型企业;3.教育版专为教育机构设计。

DBeaver和DataGrip是超越Navicat的数据库管理工具。1.DBeaver免费开源,适合小型项目,支持多种数据库。2.DataGrip功能强大,适用于复杂的大型项目,提供高级代码补全和SQL重构。

Navicat通过其直观的界面和强大功能提升数据库工作效率。1)基本用法包括连接数据库、管理表和执行查询。2)高级功能如数据同步和传输通过图形界面简化操作。3)常见错误可通过检查连接和使用语法检查功能解决。4)性能优化建议使用批量操作和定期备份。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

记事本++7.3.1
好用且免费的代码编辑器