内连接是通过在查询中设置连接条件的方式,来移除查询结果集中某些数据行后的交叉连接。简单来说,就是利用条件表达式来消除交叉连接的某些数据行。

在MySQL FROM 子句中使用关键字 INNER JOIN 连接两张表,并使用 ON 子句来设置连接条件。如果没有任何条件,INNER JOIN 和 CROSS JOIN 在语法上是等同的,两者可以互换。

语法格式如下:

SELECT <列名1,列名2 …>
FROM <表名1> INNER JOIN <表名2> [ ON子句]

语法说明如下。

  • <列名1,列名2…>:需要检索的列名。
  • <表名1><表名2>:进行内连接的两张表的表名。

内连接是系统默认的表连接,所以在 FROM 子句后可以省略 INNER 关键字,只用关键字 JOIN。使用内连接后,FROM 子句中的 ON 子句可用来设置连接表的条件。

在 FROM 子句中可以在多个表之间连续使用 INNER JOIN 或 JOIN,如此可以同时实现多个表的内连接。

【实例 1】表 tb_students_info 和表 tb_departments 都包含相同数据类型的字段 dept_id,在两个表之间使用内连接查询。输入的 SQL 语句和执行结果如下所示。

mysql> SELECT id,name,age,dept_name-> FROM tb_students_info inner join tb_departments-> WHERE tb_students_info.dept_id=tb_departments.dept_id;
+----+--------+------+-----------+
| id | name   | age  | dept_name |
+----+--------+------+-----------+
|  1 | Dany   |   25 | Computer  |
|  2 | Green  |   23 | Chinese   |
|  3 | Henry  |   23 | Math      |
|  4 | Jane   |   22 | Computer  |
|  5 | Jim    |   24 | Computer  |
|  6 | John   |   21 | Math      |
|  7 | Lily   |   22 | Computer  |
|  8 | Susan  |   23 | Economy   |
|  9 | Thomas |   22 | Chinese   |
| 10 | Tom    |   23 | Economy   |
+----+--------+------+-----------+
10 rows in set (0.00 sec)

在这里,SELECT 语句与前面介绍的最大差别是:SELECT 后面指定的列分别属于两个不同的表,id、name、age 在表 tb_students_info 中,而 dept_name 在表 tb_departments 中,同时 FROM 字句列出了两个表 tb_students_info 和 tb_departments。WHERE 子句在这里作为过滤条件,指明只有两个表中的 dept_id 字段值相等的时候才符合连接查询的条件。

返回的结果可以看到,显示的记录是由两个表中的不同列值组成的新记录。

提示:因为 tb_students_info 表和 tb_departments 表中有相同的字段 dept_id,所以在比较的时候,需要完全限定表名(格式为“表名.列名”),如果只给出 dept_id,MySQL 将不知道指的是哪一个,并返回错误信息。

【实例 2】在 tb_students_info 表和 tb_departments 表之间,使用 INNER JOIN 语法进行内连接查询,输入的 SQL 语句和执行结果如下所示。

mysql> SELECT id,name,age,dept_name-> FROM tb_students_info INNER JOIN tb_departments-> ON tb_students_info.dept_id=tb_departments.dept_id;
+----+--------+------+-----------+
| id | name   | age  | dept_name |
+----+--------+------+-----------+
|  1 | Dany   |   25 | Computer  |
|  2 | Green  |   23 | Chinese   |
|  3 | Henry  |   23 | Math      |
|  4 | Jane   |   22 | Computer  |
|  5 | Jim    |   24 | Computer  |
|  6 | John   |   21 | Math      |
|  7 | Lily   |   22 | Computer  |
|  8 | Susan  |   23 | Economy   |
|  9 | Thomas |   22 | Chinese   |
| 10 | Tom    |   23 | Economy   |
+----+--------+------+-----------+
10 rows in set (0.00 sec)

在这里的查询语句中,两个表之间的关系通过 INNER JOIN 指定。使用这种语法的时候,连接的条件使用 ON 子句给出,而不是 WHERE,ON 和 WHERE 后面指定的条件相同。

提示:使用 WHERE 子句定义连接条件比较简单明了,而 INNER JOIN 语法是 ANSI SQL 的标准规范,使用 INNER JOIN 连接语法能够确保不会忘记连接条件,而且 WHERE 子句在某些时候会影响查询的性能。

mysql inner join相关推荐

  1. 我想说:mysql 的 join 真的很弱

    (给视学算法加星标,提高Java技能) 转自:ITPUB博客,作者:e71hao blog.itpub.net/30393770/viewspace-2650450/ 一. 问题提出: <阿里巴 ...

  2. mysql right join实例_MySQL表LEFT JOIN左连接与RIGHT JOIN右连接的实例教程

    LEFT JOIN 语法用法与实例MySQL LEFT JOIN 语法 SQL(MySQL) LEFT JOIN 会取得左表(table1)全部记录,即使右表(table2)并无对应匹配记录.LEFT ...

  3. MySQL的JOIN(一):用法

    JOIN的含义就如英文单词"join"一样,连接两张表,大致分为内连接,外连接,右连接,左连接,自然连接.这里描述先甩出一张用烂了的图,然后插入测试数据. 复制代码 CREATE ...

  4. mysql natural join用法_MySQL NATURAL JOIN

    NATURAL JOIN 也叫自然连接,实际是属于 JOIN 的一种. MySQL NATURAL JOIN 语法如下: ... FROM table1 NATURAL JOIN table2 ... ...

  5. mysql的join语句使用_在MySQL中使用JOIN语句进行连接操作的详细教程

    到目前,我们已经学习了从一个表中获取数据.这是简单的需要,但在大多数现实MySQL的使用,经常需要将数据从多个表中的一个单一的查询. 可以使用多个表中的单一SQL查询.在MySQL中联接(join)行 ...

  6. mysql默认join是什么类型_MySQL:join语句类型

    MySQL:join语句类型 join从句的类型有以下几种: 内链接(inner) 右外连接(right outer) 左外连接(left outer) 全外连接(full outer) 交叉链接(c ...

  7. 一文搞懂MySQL的Join

    点击上方 "程序员小乐" ,关注公众号 8点20分,第一时间与你相约 每日英文 A single hand that wipes tears during failures is ...

  8. mysql inner join where_详解mysql 使用left join添加where条件的问题分析

    当前需求: 有group和factor两张表,一个group对应多个factor,现在想查询有效的group和对应的有效的factor,两个表都有isDel逻辑删除标志. 最开始的错误写法一: SEL ...

  9. 我想说:mysql 的 join 真的很弱|文末福利

    转自:ITPUB博客,作者:e71hao blog.itpub.net/30393770/viewspace-2650450/ 一. 问题提出: <阿里巴巴JAVA开发手册>里面写超过三张 ...

  10. MySQL的JOIN用法

    全文共925个字,10张图,预计阅读时间6分钟. 数据库中的JOIN称为连接,连接的主要作用是根据两个或多个表中的列之间的关系,获取存在于不同表中的数据.连接分为三类:内连接.外连接.全连接.另外还有 ...

最新文章

  1. 三、CXF对Interceptor拦截器的支持
  2. Apache 超详细编译参数解析
  3. gcc build a project
  4. Spring(四)——AOP、Spring实现AOP、Spring整合Mybatis、Spring中的事务管理
  5. 真相残酷:如何衡量自己是否适合做科研?
  6. 探讨Redhat的开源“成功之道”
  7. nutch的index-writers.xml
  8. 搜索引擎设计实用教程(1)-以百度为例
  9. django集成ansibe实现自动化
  10. android中打开pdf,在Android应用程序中打开PDF
  11. java为table添加一行_Js实现Table动态添加一行的小例子
  12. PyTorch学习笔记——语言模型
  13. 【C#】使用OWIN创建Web API
  14. .fit文件读取--head信息--修改head--读取csv文件-------ska暑期训练
  15. 「陶哲軒實分析」 習題 3.5.1
  16. 装饰者模式的应用:react高阶组件和ES6 装饰器
  17. 计算几何——点到直线的距离、投影点
  18. 智能晾衣器全国产化电子元件推荐方案
  19. 台式计算机硬件办公配置清单,颜值满分的办公台式电脑,分享配置清单
  20. 微信跑腿小程序怎么做

热门文章

  1. windows 2008R2 无法安装操作系统补丁,或无法安装Sp1升级包的解决办法
  2. 大四中软实习笔记201303011文件
  3. 时间选择器 可以选择日期和时间
  4. MOSS 2007基础:WSS 3.0 中的母版页(Master Pages)和内容页(Content Pages)
  5. 【数据结构与算法】之深入解析“下一个更大元素II”的求解思路与算法示例
  6. 【数据结构与算法】之深入解析“旋转链表”的求解思路与算法示例
  7. 【数据结构与算法】之深入解析运用链表结构计算“两数相加”的算法实现
  8. 10.2.3 基本属性
  9. django makemigrtions时出现no changes detected 解决方式
  10. 全国大学生电子设计大赛 赛前准备