文章详情

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

请输入下面的图形验证码

提交验证

短信预约提醒成功

mysql中怎么创建和查询外键

2023-07-06 12:00

关注

本篇内容主要讲解“mysql中怎么创建和查询外键”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mysql中怎么创建和查询外键”吧!

一、什么是外键

外键是一个表格中的一列或多列,它用于指定这个列或多列中的值必须与另一个表格中的数据或者另一个表格中的主键相匹配。这个被匹配的表格称为被参考表。在一个关系型数据库中,当我们想要链接两个或多个表格时,我们就可以使用外键。

外键的目的是用来确保数据的完整性和一致性。当我们在一个表格中加入一行数据时,如果这个数据需要和另一个表格中的某些数据匹配,如果这个匹配关系是通过外键建立的,那么MySQL就会检查这个新增数据中的外键,看看在被参考表格中是否存在这个数据,如果不存在,就会拒绝在这个表格中插入这个数据。

二、如何创建外键

在MySQL中创建外键有多种方式,以下是两种比较常用的方式。

使用 ALTER TABLE 语句

通过 ALTER TABLE 语句添加外键的语法格式如下:

ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (列名) REFERENCES 另一个表格的表名 (列名);

其中,外键名称是给外键的一个名称,这个名称应该具有唯一性,列名指的是当前表格的列名,另一个表格的表明和列名分别是被参考表的名称和被参考表的列名。

例如,我们有一个员工表(employees)和一个部门表(departments),他们之间是通过一个外键链接的,我们可以使用以下SQL语句创建这个外键。

ALTER TABLE employees ADD CONSTRAINT dept_fk FOREIGN KEY (dept_id) REFERENCES departments (dept_id);

这个语句的意思是,给员工表(employees)添加名为 dept_fk 的外键,dept_fk 指向employees表的dept_id列,它参考了departments表的dept_id列。

在创建表格时定义外键

在创建表格时定义外键也是一种常用的方式。语法格式如下:

CREATE TABLE 表名 (列名 数据类型,外键名称 FOREIGN KEY (列名) REFERENCES 另一个表格的表名 (列名));

例如,创建一个员工表(employees)和一个部门表(departments),并且使用dept_id列作为employees表的外键链接departments表的dept_id列,可以使用以下的SQL语句。

CREATE TABLE employees (id INT NOT NULL,name VARCHAR(50) NOT NULL,dept_id INT,PRIMARY KEY (id),FOREIGN KEY (dept_id) REFERENCES departments (dept_id))

三、如何查询外键

当在MySQL中建立了外键以后,我们就可以使用 MySQL 的查询语句查询外键了。查询外键的语法格式如下:

SELECT * FROM 表名 WHERE 列名 IS NULL;

这个语句返回的是表格中列名为空的数据,如果这个列是被定义为外键的,那么这个查询结果就是表格中与外键没有匹配行的数据。这个查询结果是非常有用的,它可以帮助我们找出那些需要手动解决,没有被正确匹配的记录。

例如,我们有一个 departments 表格,它的 dept_id 列被定义为外键,如果我们想要查询出那些在 departments 表格中没有匹配的记录,可以使用以下的SQL语句:

SELECT * FROM departments WHERE dept_id NOT IN (SELECT dept_id FROM employees);

这个语句的意思是,查询在 departments 表格中不包含在 employees 表格中的 dept_id 数据。

到此,相信大家对“mysql中怎么创建和查询外键”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

阅读原文内容投诉

免责声明:

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

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

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯