MariaDB中Intersect的用法是什么,有何事项要注意

Admin 2022-06-30 群英技术资讯 454 次浏览

这篇文章主要介绍了MariaDB中Intersect的用法是什么,有何事项要注意相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇MariaDB中Intersect的用法是什么,有何事项要注意文章都会有所收获,下面我们一起来看看吧。

INTERSECT运算符用于返回2个或更多表的交集。 如果两个表中都存在记录,它将被包含在INTERSECT结果中。 否则,它将从INTERSECT结果中被省略。

语法

SELECT expression1, expression2, ... expression_n  
FROM tables  
[WHERE conditions]  
INTERSECT  
SELECT expression1, expression2, ... expression_n  
FROM tables  
[WHERE conditions];

说明图如下所示 -

注意:MariaDB不支持INTERSECT运算符,但是通过使用IN运算符来模拟INTERSECT查询,可以看到相同的结果,如下示例中所示。

1. INTERSECT运算符返回单个字段

以下是针对INTERSECT运算符的一般查询,但不会在MariaDB中超混杂。

假设有两张表:studentsteachers。对应的表结构和数据如下 -

students表中的数据:

MariaDB [testdb]> select * from students;
+------------+--------------+-----------------+----------------+
| student_id | student_name | student_address | admission_date |
+------------+--------------+-----------------+----------------+
|          1 | Maxsu        | Haikou          | 2017-01-07     |
|          2 | JMaster      | Beijing         | 2016-05-07     |
|          3 | Mahesh       | Guangzhou       | 2016-06-07     |
|          4 | Kobe         | Shanghai        | 2016-02-07     |
|          5 | Blaba        | Shenzhen        | 2016-08-07     |
+------------+--------------+-----------------+----------------+
5 rows in set (0.00 sec)

teachers表中的数据:

USE testdb;
DROP TABLE teachers;
CREATE TABLE teachers(  
    teacher_id INT NOT NULL AUTO_INCREMENT,  
    name VARCHAR(100) NOT NULL,  
    address VARCHAR(40) NOT NULL,  
    admission_date DATE,  
    PRIMARY KEY ( teacher_id )
);
-- 插入数据
INSERT INTO teachers  
(teacher_id, name, address, admission_date)  
VALUES(1,'Maxsu','Haikou','2013-06-07 00:00:00');

INSERT INTO teachers  
(teacher_id, name, address, admission_date)  
VALUES(2,'张天经','广州','2013-08-08 00:00:00');

INSERT INTO teachers  
(teacher_id, name, address, admission_date)  
VALUES(3,'李四光','三亚','2014-09-07 00:00:00');

经过上创建和插入数据,现在teachers表中拥有以下数据记录 -

MariaDB [testdb]> select * from teachers;
+------------+--------+---------+----------------+
| teacher_id | name   | address | admission_date |
+------------+--------+---------+----------------+
|          1 | Maxsu  | Haikou  | 2013-06-07     |
|          2 | 张天经 | 广州    | 2013-08-08     |
|          3 | 李四光 | 三亚    | 2014-09-07     |
+------------+--------+---------+----------------+
3 rows in set (0.00 sec)

假设现在要查询学生和老师的姓名有哪几个?参考以下查询语句 -

-- 理想语句,但是MariaDB中不支持 
SELECT student_name  
FROM Students
INTERSECT  
SELECT name  
FROM teachers;

上面语句的代替语句是 -

SELECT s.student_name AS name
FROM Students s
WHERE s.student_name IN (SELECT t.name FROM teachers t);

执行上面查询语句,得到以下结果 -

MariaDB [testdb]> SELECT s.student_name AS name
    -> FROM Students s
    -> WHERE s.student_name IN (SELECT t.name FROM teachers t);
+-------+
| name  |
+-------+
| Maxsu |
+-------+
1 row in set (0.10 sec)

它显示了两个表中name列都有存在的值 - 'Maxsu'

2. INTERSECT运算符指定WHERE条件

以下是针对INTERSECT运算符的一般查询,但不能在MariaDB中正常使用。参考以下语句 -

-- 理想语句,但是MariaDB中不支持 
SELECT s.student_name  
FROM Students s WHERE student_id<100
INTERSECT  
SELECT t.name  
FROM teachers t
WHERE t.address = 'Haikou';

上面语句的代替语句是 -

SELECT s.student_name AS name
FROM Students s
WHERE s.student_id<100 AND s.student_name IN (SELECT t.name FROM teachers t  WHERE t.address = 'Haikou');

执行上面示例代码,得到以下结果 -

MariaDB [testdb]> SELECT s.student_name AS name
    -> FROM Students s
    -> WHERE s.student_id<100 AND s.student_name IN (SELECT t.name FROM teachers t  WHERE t.address = 'Haikou');
+-------+
| name  |
+-------+
| Maxsu |
+-------+
1 row in set (0.00 sec)

“MariaDB中Intersect的用法是什么,有何事项要注意”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业技术相关的知识可以关注群英网络网站,小编每天都会为大家更新不同的知识。 群英智防CDN,智能加速解决方案
标签: Intersect运算符

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

猜你喜欢

成为群英会员,开启智能安全云计算之旅

立即注册
专业资深工程师驻守
7X24小时快速响应
一站式无忧技术支持
免费备案服务
免费拨打  400-678-4567
免费拨打  400-678-4567 免费拨打 400-678-4567 或 0668-2555555
在线客服
微信公众号
返回顶部
返回顶部 返回顶部
在线客服
在线客服