mysql 有没有minus_MySQL实现差集(Minus)和交集(Intersect)测试报告

可以用SQL实现同样的功能,就是麻烦了点。

drop table t1;

drop table t2;

create table t1(id int primary key,nickname varchar(20),playNum varchar(20));

create table t2(id int primary key,nickname varchar(20),playNum varchar(20));

insert into t1 values(1,1,10);

insert into t1 values(2,2,20);

insert into t1 values(3,3,30);

insert into t2 values(1,1,10);

insert into t2 values(2,2,200);

insert into t2 values(3,33,300);

commit;

34937_0.jpg

MySQL实现交集

SELECT id, nickname, playNum, COUNT(*)

FROM (SELECT id, nickname, playNum

FROM t1

UNION ALL

SELECT id, nickname, playNum

FROM t2

) a

GROUP BY id, nickname, playNum

HAVING COUNT(*) > 1

34937_1.jpg

MySQL实现差集

SELECT t1.id, t1.nickname, t1.playNum

FROM t1 LEFT JOIN t2 ON t1.id = t2.id

WHERE t1.nickname != t2.nickname

OR t1.playNum != t2.playNum;

34937_2.jpg

MySQL中可以使用UNION、INTERSECT和EXCEPT(或称为MINUS)来进行并集、交集差集的操作。 - 并集(UNION):使用UNION操作符可以将两个或多个SELECT语句的结果合并成一个结果集。要求每个SELECT语句中选择的列的数量和数据类型必须一致。例如: ``` SELECT column1, column2, column3 FROM table1 UNION SELECT column1, column2, column3 FROM table2; ``` 这将返回table1和table2中所有行的并集。 - 交集INTERSECT):MySQL不直接支持INTERSECT操作符,但可以使用INNER JOIN来实现交集操作。例如: ``` SELECT column1, column2, column3 FROM table1 INNER JOIN table2 ON table1.column1 = table2.column1; ``` 这将返回table1和table2中共有的行。 - 差集(EXCEPT):MySQL也不直接支持EXCEPT操作符,但可以使用LEFT JOIN和WHERE子句来实现差集操作。例如: ``` SELECT column1, column2, column3 FROM table1 LEFT JOIN table2 ON table1.column1 = table2.column1 WHERE table2.column1 IS NULL; ``` 这将返回在table1中存在但在table2中不存在的行。 请注意,以上示例中的表名、列名和条件应根据实际情况进行替换。 #### 引用[.reference_title] - *1* [MySQL 查询 并集、交集差集](https://blog.csdn.net/AI_SupplyChain/article/details/111567920)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [mysql 交集,并集(union),差集](https://blog.csdn.net/qq_39496303/article/details/121314313)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值