亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL聯(lián)表查詢基本操作之left-join常見(jiàn)的坑

 更新時(shí)間:2020年05月17日 15:46:21   作者:當(dāng)我遇上你  
這篇文章主要給大家介紹了關(guān)于MySQL聯(lián)表查詢基本操作之left-join的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用MySQL具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

概述

對(duì)于中小體量的項(xiàng)目而言,聯(lián)表查詢是再常見(jiàn)不過(guò)的操作了,尤其是在做報(bào)表的時(shí)候。然而校對(duì)數(shù)據(jù)的時(shí)候,您發(fā)現(xiàn)坑了嗎?本篇文章就 mysql 常用聯(lián)表查詢復(fù)現(xiàn)常見(jiàn)的坑。

基礎(chǔ)環(huán)境

建表語(yǔ)句

DROP TABLE IF EXISTS `role`;
CREATE TABLE `role` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `role_name` VARCHAR(50) DEFAULT NULL COMMENT '角色名',
 PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='角色表';


insert into `role` VALUES(1, '管理員');
insert into `role` VALUES(2, '總經(jīng)理');
insert into `role` VALUES(3, '科長(zhǎng)');
insert into `role` VALUES(4, '組長(zhǎng)');

DROP TABLE IF EXISTS `user`;
CREATE TABLE `user` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `role_id` int(11) NOT NULL COMMENT '角色id',
 `user_name` VARCHAR(50) DEFAULT NULL COMMENT '用戶名',
 `sex` int(1) DEFAULT 0 COMMENT '性別',
 PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='用戶表';

insert into `user` VALUES(1, 1, 'admin', 1);
insert into `user` VALUES(2, 2, '王經(jīng)理', 1);
insert into `user` VALUES(3, 2, '李經(jīng)理', 2);
insert into `user` VALUES(4, 2, '張經(jīng)理', 2);
insert into `user` VALUES(5, 3, '王科長(zhǎng)', 1);
insert into `user` VALUES(6, 3, '李科長(zhǎng)', 1);
insert into `user` VALUES(7, 3, '呂科長(zhǎng)', 2);
insert into `user` VALUES(8, 3, '邢科長(zhǎng)', 1);
insert into `user` VALUES(9, 4, '范組長(zhǎng)', 2);
insert into `user` VALUES(10, 4, '趙組長(zhǎng)', 2);
insert into `user` VALUES(11, 4, '姬組長(zhǎng)', 1);

數(shù)據(jù)如下

mysql> select * from role;
+----+-----------+
| id | role_name |
+----+-----------+
| 1 | 管理員  |
| 2 | 總經(jīng)理  |
| 3 | 科長(zhǎng)   |
| 4 | 組長(zhǎng)   |
+----+-----------+
4 rows in set (0.00 sec)

mysql> select * from user;
+----+---------+-----------+------+
| id | role_id | user_name | sex |
+----+---------+-----------+------+
| 1 |    1 | admin   |  1 |
| 2 |    2 | 王經(jīng)理  |  1 |
| 3 |    2 | 李經(jīng)理  |  2 |
| 4 |    2 | 張經(jīng)理  |  2 |
| 5 |    3 | 王科長(zhǎng)  |  1 |
| 6 |    3 | 李科長(zhǎng)  |  1 |
| 7 |    3 | 呂科長(zhǎng)  |  2 |
| 8 |    3 | 邢科長(zhǎng)  |  1 |
| 9 |    4 | 范組長(zhǎng)  |  2 |
| 10 |    4 | 趙組長(zhǎng)  |  2 |
| 11 |    4 | 姬組長(zhǎng)  |  1 |
+----+---------+-----------+------+
11 rows in set (0.00 sec)

基本業(yè)務(wù)

簡(jiǎn)單信息報(bào)表: 查詢用戶信息

mysql> SELECT
  -> id,
  -> user_name AS '姓名',
  -> ( CASE WHEN sex = 1 THEN '男' WHEN sex = 2 THEN '女' ELSE '未知' END ) AS '性別'
  -> FROM
  -> USER;
+----+-----------+--------+
| id | 姓名   | 性別  |
+----+-----------+--------+
| 1 | admin   | 男   |
| 2 | 王經(jīng)理  | 男   |
| 3 | 李經(jīng)理  | 女   |
| 4 | 張經(jīng)理  | 女   |
| 5 | 王科長(zhǎng)  | 男   |
| 6 | 李科長(zhǎng)  | 男   |
| 7 | 呂科長(zhǎng)  | 女   |
| 8 | 邢科長(zhǎng)  | 男   |
| 9 | 范組長(zhǎng)  | 女   |
| 10 | 趙組長(zhǎng)  | 女   |
| 11 | 姬組長(zhǎng)  | 男   |
+----+-----------+--------+

查詢每個(gè)角色名稱及對(duì)應(yīng)人員中女性數(shù)量

mysql> SELECT
  -> r.id,
  -> r.role_name AS role,
  -> count( u.sex ) AS sex
  -> FROM
  -> role r
  -> LEFT JOIN USER u ON r.id = u.role_id
  -> AND u.sex = 2
  -> GROUP BY
  -> r.role_name
  -> ORDER BY
  -> r.id ASC;
+----+-----------+-----+
| id | role   | sex |
+----+-----------+-----+
| 1 | 管理員  |  0 |
| 2 | 總經(jīng)理  |  2 |
| 3 | 科長(zhǎng)   |  1 |
| 4 | 組長(zhǎng)   |  2 |
+----+-----------+-----+
4 rows in set (0.00 sec)

假如我們把性別過(guò)濾的條件改為 where 操作結(jié)果會(huì)怎么樣呢?

mysql> SELECT
  -> r.id,
  -> r.role_name AS role,
  -> count( u.sex ) AS sex
  -> FROM
  -> role r
  -> LEFT JOIN USER u ON r.id = u.role_id
  -> WHERE
  -> u.sex = 2
  -> GROUP BY
  -> r.role_name
  -> ORDER BY
  -> r.id ASC;
+----+-----------+-----+
| id | role   | sex |
+----+-----------+-----+
| 2 | 總經(jīng)理  |  2 |
| 3 | 科長(zhǎng)   |  1 |
| 4 | 組長(zhǎng)   |  2 |
+----+-----------+-----+
3 rows in set (0.00 sec)

這里可以看到角色數(shù)據(jù)不完整了。

找出角色為總經(jīng)理的員工數(shù)量

mysql> SELECT
  -> r.id,
  -> r.role_name AS role,
  -> count( u.sex ) AS sex
  -> FROM
  -> role r
  -> LEFT JOIN USER u ON r.id = u.role_id
  -> WHERE
  -> r.role_name = '總經(jīng)理'
  -> GROUP BY
  -> r.role_name
  -> ORDER BY
  -> r.id ASC;
+----+-----------+-----+
| id | role   | sex |
+----+-----------+-----+
| 2 | 總經(jīng)理  |  3 |
+----+-----------+-----+
1 row in set (0.00 sec)

同樣將過(guò)濾條件由 where 改為 on

mysql> SELECT
  -> r.id,
  -> r.role_name AS role,
  -> count( u.sex ) AS sex
  -> FROM
  -> role r
  -> LEFT JOIN USER u ON r.id = u.role_id
  -> AND r.role_name = '總經(jīng)理'
  -> GROUP BY
  -> r.role_name
  -> ORDER BY
  -> r.id ASC;
+----+-----------+-----+
| id | role   | sex |
+----+-----------+-----+
| 1 | 管理員  |  0 |
| 2 | 總經(jīng)理  |  3 |
| 3 | 科長(zhǎng)   |  0 |
| 4 | 組長(zhǎng)   |  0 |
+----+-----------+-----+
4 rows in set (0.00 sec)

這里可以看到數(shù)據(jù)多余了

總結(jié)

在 left join 語(yǔ)句中,左表過(guò)濾必須放 where 條件中,右表過(guò)濾必須放 on 條件中,這樣結(jié)果才能不多不少,剛剛好。

到此這篇關(guān)于MySQL聯(lián)表查詢基本操作之left-join常見(jiàn)坑的文章就介紹到這了,更多相關(guān)MySQL聯(lián)表查詢left-join內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • mysql 8.0.11 winx64安裝配置方法圖文教程

    mysql 8.0.11 winx64安裝配置方法圖文教程

    這篇文章主要為大家詳細(xì)介紹了mysql 8.0.11 winx64安裝配置方法圖文教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • 一文總結(jié)使用MySQL時(shí)遇到null值的坑

    一文總結(jié)使用MySQL時(shí)遇到null值的坑

    這篇文章給大家總結(jié)了日常使用MySQL時(shí),容易遇到NULL值的坑有哪些,文章通過(guò)代碼示例給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-01-01
  • MySQL慢查詢?nèi)罩境敿?xì)總結(jié)

    MySQL慢查詢?nèi)罩境敿?xì)總結(jié)

    mysql的慢查詢?nèi)罩臼莔ysql提供的一種日志記錄,它用來(lái)記錄在mysql中響應(yīng)時(shí)間超過(guò)閾值的語(yǔ)句,下面這篇文章主要給大家介紹了關(guān)于MySQL慢查詢?nèi)罩镜南嚓P(guān)資料,需要的朋友可以參考下
    2023-05-05
  • mysql 8.0.21 安裝配置方法圖文教程

    mysql 8.0.21 安裝配置方法圖文教程

    這篇文章主要為大家詳細(xì)介紹了mysql 8.0.21 安裝配置方法圖文教程,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-07-07
  • mysql下的max_allowed_packet參數(shù)設(shè)置詳解

    mysql下的max_allowed_packet參數(shù)設(shè)置詳解

    本文主要介紹了mysql下的max_allowed_packet參數(shù)設(shè)置詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • MySQL性能監(jiān)控軟件Nagios的安裝及配置教程

    MySQL性能監(jiān)控軟件Nagios的安裝及配置教程

    這篇文章主要介紹了MySQL性能監(jiān)控軟件Nagios的安裝及配置教程,這里以CentOS操作系統(tǒng)為環(huán)境進(jìn)行演示,需要的朋友可以參考下
    2015-12-12
  • Centos7.5安裝mysql5.7.24二進(jìn)制包方式部署

    Centos7.5安裝mysql5.7.24二進(jìn)制包方式部署

    這篇文章主要介紹了Centos7.5安裝mysql5.7.24二進(jìn)制包方式部署,本文分步驟給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-12-12
  • mysql增量備份及斷點(diǎn)恢復(fù)腳本實(shí)例

    mysql增量備份及斷點(diǎn)恢復(fù)腳本實(shí)例

    生產(chǎn)環(huán)境中在mysql中誤操作是非常正常的,所以就需要用到mysql的增量備份恢復(fù)。增量備份是我們經(jīng)常用到的,它可以指定某個(gè)誤操作的時(shí)間以及位置點(diǎn)進(jìn)行數(shù)據(jù)恢復(fù),更加準(zhǔn)確的恢復(fù)我們想要還原的數(shù)據(jù)。
    2018-09-09
  • Mysql中文漢字轉(zhuǎn)拼音的實(shí)現(xiàn)(每個(gè)漢字轉(zhuǎn)換全拼)

    Mysql中文漢字轉(zhuǎn)拼音的實(shí)現(xiàn)(每個(gè)漢字轉(zhuǎn)換全拼)

    這篇文章主要介紹了Mysql中文漢字轉(zhuǎn)拼音的實(shí)現(xiàn),并且每個(gè)漢字會(huì)轉(zhuǎn)換全拼,使用Mysql自定義函數(shù)實(shí)現(xiàn),需要的朋友可以參考下
    2014-06-06
  • MySQL排序優(yōu)化詳細(xì)解析

    MySQL排序優(yōu)化詳細(xì)解析

    這篇文章主要介紹了MySQL排序優(yōu)化詳細(xì)解析,MySQL有兩種方式生成有序的結(jié)果:1.通過(guò)排序操作;2.按索引順序掃描,如果EXPLAIN出來(lái)的type列的值為"index",則說(shuō)明使用了索引掃描來(lái)做排序,需要的朋友可以參考下
    2024-01-01

最新評(píng)論