【MySQL笔记】七种JOIN的SQL

准备数据

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

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

标签表如下:

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

一、左连接(LEFT JOIN)

 

问题回答个数标签id标签名称
Java是什么?51java
PHP是什么?42php
前端是什么?33大前端
nodejs是什么?2NULLNULL
css是什么?1NULLNULL
JavaScript是什么?1NULLNULL

    

  1. SELECT  
  2.     tq.title, tq.answer_count, tl.id, tl.name 
  3. FROM  
  4.     t_qa tq LEFT JOIN t_label tl ON tq.label_id = tl.id  

二、右连接(RIGHT JOIN)

 

问题回答个数标签id标签名称
Java是什么?51java
PHP是什么?42php
前端是什么?33大前端
NULLNULL4mybatis
NULLNULL5python
NULLNULL6多线程

 

  1. SELECT  
  2.    tq.title, tq.answer_count, tl.id, tl.name 
  3. FROM  
  4.     t_qa tq RIGHT JOIN t_label tl ON tq.label_id = tl.id  

三、内连接(INNER JOIN)

 

问题回答个数标签id标签名称
Java是什么?51java
PHP是什么?42php
前端是什么?33大前端

   

  1. SELECT  
  2.     tq.title, tq.answer_count, tl.id, tl.name 
  3. FROM  
  4.     t_qa tq INNER JOIN t_label tl ON tq.label_id = tl.id  

四、左独有连接(LEFT JOIN)

 

问题回答个数标签id标签名称
nodejs是什么?2NULLNULL
css是什么?1NULLNULL
JavaScript是什么?0NULLNULL

    

  1. SELECT  
  2.     tq.title, tq.answer_count, tl.id, tl.name 
  3. FROM  
  4.     t_qa tq LEFT JOIN t_label tl ON tq.label_id = tl.id 
  5. WHERE 
  6.     tl.id IS NULL  

五、右独有连接(RIGHT JOIN)

 

问题回答个数标签id标签名称
NULLNULL4mybatis
NULLNULL5python
NULLNULL6多线程

    

  1. SELECT  
  2.     tq.title, tq.answer_count, tl.id, tl.name 
  3. FROM  
  4.     t_qa tq RIGHT JOIN t_label tl ON tq.label_id = tl.id 
  5. WHERE 
  6.     tq.label_id IS NULL  

六、全连接(FULL JOIN)

 

由于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多线程

    

  1. 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 
  2. UNION 
  3. 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)

 

问题回答个数标签id标签名称
nodejs是什么?2NULLNULL
css是什么?1NULLNULL
JavaScript是什么?0NULLNULL
NULLNULL4mybatis
NULLNULL5python
NULLNULL6多线程

    

  1. 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 
  2. UNION 
  3. 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  

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/235342.html<

(0)
运维的头像运维
上一篇2025-04-21 12:26
下一篇 2025-04-21 12:27

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注