返回顶部
首页 > 资讯 > 数据库 >MySQL中七种JOIN的SQL是怎样的
  • 300
分享到

MySQL中七种JOIN的SQL是怎样的

2024-04-02 19:04:59 300人浏览 泡泡鱼
摘要

这篇文章将为大家详细讲解有关Mysql中七种JOIN的sql是怎样的,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。准备数据以一个简易问答系统为例,包括问题表

这篇文章将为大家详细讲解有关Mysql中七种JOIN的sql是怎样的,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

准备数据

以一个简易问答系统为例,包括问题表和问题所属标签,问题表如下:

CREATE TABLE `t_qa` (   `id` bigint(20) NOT NULL AUTO_INCREMENT,   `title` varchar(200) NOT NULL DEFAULT '' COMMENT '标题',   `answer_count` int(5) unsigned NOT NULL DEFAULT '0' COMMENT '回答个数',   `label_id` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '标签id',   `create_by` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '创建人',   `create_date` datetime NOT NULL DEFAULT '0000-00-00 00:00:00' COMMENT '创建时间',   `update_by` bigint(20) unsigned DEFAULT NULL COMMENT '更新人',   `update_date` datetime DEFAULT NULL COMMENT '更新时间',   `del_flag` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '0:不删除,1:删除',   PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;  INSERT INTO `t_qa` (`id`, `title`, `answer_count`, `label_id`, `create_by`, `create_date`, `update_by`, `update_date`, `del_flag`) VALUES     (1, 'Java是什么?', 5, 1, 0, '2017-08-24 17:43:53', 0, '2017-08-24 17:43:53', 0),     (2, 'PHP是什么?', 4, 2, 0, '2017-08-24 17:43:53', 0, '2017-08-24 17:43:53', 0),     (3, '前端是什么?', 3, 3, 0, '2017-08-24 17:43:53', 0, '2017-08-24 17:43:53', 0),     (4, 'nodejs是什么?', 2, 0, 0, '2017-08-24 17:43:53', 0, '2017-08-24 17:43:53', 0),     (5, 'CSS是什么?', 1, 0, 0, '2017-08-24 17:43:53', 0, '2017-08-24 17:43:53', 0),     (6, 'javascript是什么?', 0, 0, 0, '2017-08-24 17:43:53', 0, '2017-08-24 17:43:53', 0);

标签表如下:

CREATE TABLE `t_label` (   `id` bigint(20) NOT NULL AUTO_INCREMENT,   `name` varchar(50) NOT NULL DEFAULT '' COMMENT '名称',   `create_by` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '创建人',   `create_date` datetime NOT NULL DEFAULT '0000-00-00 00:00:00' COMMENT '创建时间',   `update_by` bigint(20) unsigned DEFAULT NULL COMMENT '更新人',   `update_date` datetime DEFAULT NULL COMMENT '更新时间',   `del_flag` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '0:不删除,1:删除',   PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;  INSERT INTO `t_label` (`id`, `name`, `create_by`, `create_date`, `update_by`, `update_date`, `del_flag`) VALUES     (1, 'java', 0, '2017-08-24 17:43:53', 0, '2017-08-24 17:43:53', 0),     (2, 'php', 0, '2017-08-24 17:43:53', 0, '2017-08-24 17:43:53', 0),     (3, '大前端', 0, '2017-08-24 17:43:53', 0, '2017-08-24 17:43:53', 0),     (4, 'mybatis', 0, '2017-08-24 17:43:53', 0, '2017-08-24 17:43:53', 0),     (5, 'python', 0, '2017-08-24 17:43:53', 0, '2017-08-24 17:43:53', 0),     (6, '多线程', 0, '2017-08-24 17:43:53', 0, '2017-08-24 17:43:53', 0);

一、左连接(LEFT JOIN)

MySQL中七种JOIN的SQL是怎样的

问题回答个数标签id标签名称
Java是什么?51java
PHP是什么?42php
前端是什么?33大前端
nodejs是什么?2NULLNULL
css是什么?1NULLNULL
JavaScript是什么?1NULLNULL
SELECT      tq.title, tq.answer_count, tl.id, tl.name FROM      t_qa tq LEFT JOIN t_label tl ON tq.label_id = tl.id

二、右连接(RIGHT JOIN)

MySQL中七种JOIN的SQL是怎样的

问题回答个数标签id标签名称
Java是什么?51java
PHP是什么?42php
前端是什么?33大前端
NULLNULL4mybatis
NULLNULL5Python
NULLNULL6线程
SELECT     tq.title, tq.answer_count, tl.id, tl.name FROM      t_qa tq RIGHT JOIN t_label tl ON tq.label_id = tl.id

三、内连接(INNER JOIN)

MySQL中七种JOIN的SQL是怎样的

问题回答个数标签id标签名称
Java是什么?51java
PHP是什么?42php
前端是什么?33大前端
SELECT      tq.title, tq.answer_count, tl.id, tl.name FROM      t_qa tq INNER JOIN t_label tl ON tq.label_id = tl.id

四、左独有连接(LEFT JOIN)

MySQL中七种JOIN的SQL是怎样的

问题回答个数标签id标签名称
nodejs是什么?2NULLNULL
css是什么?1NULLNULL
JavaScript是什么?0NULLNULL
SELECT      tq.title, tq.answer_count, tl.id, tl.name FROM      t_qa tq LEFT JOIN t_label tl ON tq.label_id = tl.id WHERE     tl.id IS NULL

五、右独有连接(RIGHT JOIN)

MySQL中七种JOIN的SQL是怎样的

问题回答个数标签id标签名称
NULLNULL4mybatis
NULLNULL5python
NULLNULL6多线程
SELECT      tq.title, tq.answer_count, tl.id, tl.name FROM      t_qa tq RIGHT JOIN t_label tl ON tq.label_id = tl.id WHERE     tq.label_id IS NULL

六、全连接(FULL JOIN)

MySQL中七种JOIN的SQL是怎样的

由于mysql不支持FULL OUTER JOIN,所以如果有全连接需求时,可用表达式:full outer join = left outer join  UNION right outer join来实现。

问题回答个数标签id标签名称
Java是什么?51java
PHP是什么?42php
前端是什么?33大前端
nodejs是什么?2NULLNULL
css是什么?1NULLNULL
JavaScript是什么?0NULLNULL
NULLNULL4mybatis
NULLNULL5python
NULLNULL6多线程
SELECT tq.title, tq.answer_count, tl.id, tl.name FROM t_qa tq LEFT JOIN t_label tl ON tq.label_id = tl.id UNioN SELECT tq.title, tq.answer_count, tl.id, tl.name FROM t_qa tq RIGHT JOIN t_label tl ON tq.label_id = tl.id

七、全连接去交集(FULL JOIN)

MySQL中七种JOIN的SQL是怎样的

问题回答个数标签id标签名称
nodejs是什么?2NULLNULL
css是什么?1NULLNULL
JavaScript是什么?0NULLNULL
NULLNULL4mybatis
NULLNULL5python
NULLNULL6多线程
SELECT tq.title, tq.answer_count, tl.id, tl.name FROM t_qa tq LEFT JOIN t_label tl ON tq.label_id = tl.id WHERE tl.id IS NULL UNION SELECT tq.title, tq.answer_count, tl.id, tl.name FROM t_qa tq RIGHT JOIN t_label tl ON tq.label_id = tl.id WHERE tq.label_id IS NULL

关于MySQL中七种JOIN的SQL是怎样的就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

您可能感兴趣的文档:

--结束END--

本文标题: MySQL中七种JOIN的SQL是怎样的

本文链接: https://lsjlt.com/news/67580.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • MySQL中七种JOIN的SQL是怎样的
    这篇文章将为大家详细讲解有关MySQL中七种JOIN的SQL是怎样的,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。准备数据以一个简易问答系统为例,包括问题表...
    99+
    2024-04-02
  • MySQL七大JOIN的具体使用
    目录简介练习简介 A的独有+AB的公有B的独有+AB的公有AB的公有A的独有B的独有A的独有+B的独有+AB的公有A的独有+B的独有 练习 建表 部门表 DROP TABL...
    99+
    2024-04-02
  • MySQL:七种 SQL JOINS 的实现(图文详解)
    MySQL:7种SQL JOINS的实现 前言一、图示表示二、代码举例1、INNER JOIN(内连接)2、LEFT JOIN(左连接)3、RIGHT JOIN(右连接)4、OUTER JOIN(全连接)5、LEFT EXCLUDI...
    99+
    2023-08-16
    mysql 数据库 sql 大数据
  • MySQL中join的有几种算法
    这篇文章主要介绍了MySQL中join的有几种算法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。我们经常在多表查询的时候使用join 去连接...
    99+
    2024-04-02
  • Android 七种进度条的样式
    当一个应用在后台执行时,前台界面就不会有什么信息,这时用户根本不知道程序是否在执行、执行进度如何、应用程序是否遇到错误终止等,这时需要使用进度条来提示用户后台程序执行的进度。A...
    99+
    2022-06-06
    进度条 Android
  • SQL中各种连接Join的示例分析
    这篇文章给大家分享的是有关SQL中各种连接Join的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。最常见的 JOIN 类型:SQL INNER JOIN(简单的 JOIN...
    99+
    2024-04-02
  • mysql中的join是什么
    mysql 中的 join 是用于组合不同表数据的查询命令,它通过匹配列创建临时表。join 有四种类型:inner join(仅匹配两表中都存在的行)、left join(选择左表所有...
    99+
    2024-04-29
    mysql
  • MySQL中SQL执行流程是怎么样的
    这篇文章主要介绍MySQL中SQL执行流程是怎么样的,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!MYSQL体系结构先看一张架构图,如下:模块详解Connector:用来支持各种语言...
    99+
    2024-04-02
  • SQL之各种join的示例分析
    这篇文章将为大家详细讲解有关SQL之各种join的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。SQL Left Join, Right Join, Inner Join, and Natural...
    99+
    2023-06-20
  • sql中cross join的用法是什么
    在SQL中,CROSS JOIN是一种用于返回两个表之间的笛卡尔积的操作。也就是说,它会返回两个表的所有可能的组合。 例如,假设有两...
    99+
    2024-04-09
    sql
  • SQL中的join总结
        oracle 中SQL的语法格式如下:    select table1.column, table2.co...
    99+
    2024-04-02
  • 【MYSQL高级】Mysql 表的七种连接方式【附带练习sql】
    文章目录 连接七种JOIN介绍练习建表+存储数据笛卡尔积内连接左连接右连接A表独有B表独有全连接实现方式一:左连接+右连接+公共部分去重实现方式二:左连接+B独有 A独有+B独有 ...
    99+
    2023-09-17
    sql mysql 数据库
  • sql中join on和join in的区别
    join on 和 join in 的区别在于:1. join on 使用相等比较条件,而 join in 可以使用任何比较运算符;2. join in 支持子查询,而 join on ...
    99+
    2024-05-08
  • mysql中的join、left join和right join的用法
    本篇内容介绍了“mysql中的join、left join和right join的用法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大...
    99+
    2024-04-02
  • SQL 中各种各样的函数
    目录一、函数的种类二、算术函数2.1 ABS——绝对值2.2 MOD——求余2.3 ROUND——四舍五入三、字符串函数3.1 ||——拼接3.2 LENGTH——字符串长度3.3 LOWER——小写转换3.4 REPLACE——...
    99+
    2018-07-05
    SQL 中各种各样的函数
  • 简单学习SQL的各种连接Join
    SQL JOIN 子句用于把来自两个或多个表的行结合起来,基于这些表之间的共同字段。 最常见的 JOIN 类型:SQL INNER JOIN(简单的 JOIN)、SQL LEFT JOIN、SQL RIGH...
    99+
    2024-04-02
  • SQL中like的写法是怎样的
    本篇内容主要讲解“SQL中like的写法是怎样的”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“SQL中like的写法是怎样的”吧!某交易系统,监控告警有长SQL...
    99+
    2024-04-02
  • SQL中join的使用方法是什么
    在SQL中,使用JOIN操作可以将两个或多个表中的行连接起来,以便进行数据查询和分析。JOIN操作的基本语法如下: SELEC...
    99+
    2023-10-26
    SQL join
  • SQL join的作用是什么
    SQL的JOIN操作用于将两个或多个表中的行连接在一起,形成一个新的结果集。JOIN操作可以根据两个或多个表之间的列的值进行连接,从...
    99+
    2023-10-07
    sql join
  • SQL JOIN的用法是什么
    SQL JOIN用于将两个或多个表按照指定的关联条件连接在一起,从而得到一个新的结果集。JOIN操作可以根据表中的列之间的关系进行连...
    99+
    2023-10-11
    SQL JOIN
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作