mysql数据库如何做这样的差集查询?

mysql数据库如何做这样的差集查询?,第1张

select URL from TABLEA 

 where   url not in (select URL from TABLEB where APP_NAME=TABLEA.APP_NAME)

求如何用mysql实现计算上下两条记录的差的方法。

如下参考:

1.创建一个表并插入数据,如下图所示。

2.按字段名顺序从表名中选择*,如下图。

3.根据班级分组程度(groupby),将数据分为三类:肉类、蔬菜和水果。

4.按类分组后,对结果进行处理,分别计算三个类的总金额。在本例中,sum是mysql提供的一个内置函数(聚合函数),它是统计组合的。

5.分组之后,可以使用聚合函数执行一系列查询 *** 作,询问每个类中有多少个查询 *** 作。

6.组后面跟着过滤器,如下所示。

CREATE TABLE A (

`C1` VARCHAR(10),

`C2` VARCHAR(10),

`C3` VARCHAR(10),

`C4` VARCHAR(10),

`C5` INT

)

INSERT INTO A

SELECT '华北', '辽宁', '沈阳', '20020202', 2 UNION ALL

SELECT '华东', '山东', '青岛', '18020133', 3 UNION ALL

SELECT '华北', '北京', '北京', '7193', 7 UNION ALL

SELECT '华北', '北京', '北京', '8358', 5 UNION ALL

SELECT '华北', '北京', '北京', '9773', 8 UNION ALL

SELECT '华东', '山东', '青岛', '18020133', 5

CREATE TABLE B (

`C1` VARCHAR(10),

`C2` VARCHAR(10),

`C3` VARCHAR(10),

`C4` VARCHAR(10),

`C5` INT

)

INSERT INTO B

SELECT '华北', '辽宁', '沈阳', '20020202', 5 UNION ALL

SELECT '华东', '山东', '青岛', '18020133', 6 UNION ALL

SELECT '华北', '北京', '北京', '7193', 2 UNION ALL

SELECT '华东', '甘肃', '兰州', '7364', 3 UNION ALL

SELECT '华东', '湖北', '武汉', '7512', 7 UNION ALL

SELECT '华东', '湖北', '武汉', '7512', 2 UNION ALL

SELECT '华东', '江苏', '常州', '7582', 5 UNION ALL

SELECT '华东', '江苏', '淮安', '7670', 7

SELECT

IFNULL(A.`C1`, B.`C1`) AS `区域`,

IFNULL(A.`C2`, B.`C2`) AS `省份`,

IFNULL(A.`C3`, B.`C3`) AS `城市`,

IFNULL(A.`C4`, B.`C4`) AS `编码`,

SUM(A.`C5`) AS `表A销量`,

SUM(B.`C5`) AS `表B销量`

FROM

A LEFT JOIN B

ON (

A.`C1` = B.`C1` AND

A.`C2` = B.`C2` AND

A.`C3` = B.`C3` AND

A.`C4` = B.`C4`

)

GROUP BY

IFNULL(A.`C1`, B.`C1`),

IFNULL(A.`C2`, B.`C2`),

IFNULL(A.`C3`, B.`C3`),

IFNULL(A.`C4`, B.`C4`)

UNION

SELECT

IFNULL(A.`C1`, B.`C1`) AS `区域`,

IFNULL(A.`C2`, B.`C2`) AS `省份`,

IFNULL(A.`C3`, B.`C3`) AS `城市`,

IFNULL(A.`C4`, B.`C4`) AS `编码`,

SUM(A.`C5`) AS `表A销量`,

SUM(B.`C5`) AS `表B销量`

FROM

A RIGHT JOIN B

ON (

A.`C1` = B.`C1` AND

A.`C2` = B.`C2` AND

A.`C3` = B.`C3` AND

A.`C4` = B.`C4`

)

GROUP BY

IFNULL(A.`C1`, B.`C1`),

IFNULL(A.`C2`, B.`C2`),

IFNULL(A.`C3`, B.`C3`),

IFNULL(A.`C4`, B.`C4`)

+------+------+------+----------+---------+---------+

| 区域 | 省份 | 城市 | 编码 | 表A销量 | 表B销量 |

+------+------+------+----------+---------+---------+

| 华北 | 辽宁 | 沈阳 | 20020202 | 2 | 5 |

| 华北 | 北京 | 北京 | 7193 | 7 | 2 |

| 华北 | 北京 | 北京 | 8358 | 5 |NULL |

| 华北 | 北京 | 北京 | 9773 | 8 |NULL |

| 华东 | 山东 | 青岛 | 18020133 | 8 | 12 |

| 华东 | 甘肃 | 兰州 | 7364 |NULL | 3 |

| 华东 | 湖北 | 武汉 | 7512 |NULL | 9 |

| 华东 | 江苏 | 常州 | 7582 |NULL | 5 |

| 华东 | 江苏 | 淮安 | 7670 |NULL | 7 |

+------+------+------+----------+---------+---------+

9 rows in set (0.00 sec)


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/7383037.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-05
下一篇 2023-04-05

发表评论

登录后才能评论

评论列表(0条)

保存