日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

mysql left join 查询_MySQL联表查询基本操作之left-join常见的坑

發(fā)布時(shí)間:2023/12/15 数据库 17 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql left join 查询_MySQL联表查询基本操作之left-join常见的坑 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

概述

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

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

建表語句

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)

假如我們把性別過濾的條件改為 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)

同樣將過濾條件由 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 語句中,左表過濾必須放 where 條件中,右表過濾必須放 on 條件中,這樣結(jié)果才能不多不少,剛剛好。

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

總結(jié)

以上是生活随笔為你收集整理的mysql left join 查询_MySQL联表查询基本操作之left-join常见的坑的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。