MariaDB中Intersect的用法是什么,有何事项要注意
Admin 2022-06-30 群英技术资讯 454 次浏览
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
查询,可以看到相同的结果,如下示例中所示。
以下是针对INTERSECT
运算符的一般查询,但不会在MariaDB中超混杂。
假设有两张表:students
和teachers
。对应的表结构和数据如下 -
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'
。
以下是针对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)
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
在本章中,我们将学习删除表。下文有详解方法和实例,内容详细,逻辑清晰,有需要的朋友可以参考,希望大家阅读完这篇文章后能有所收获,那么下面就一起来了解一下吧。
UPDATE命令通过更改值来修改现有字段。 它使用SET子句指定要修改的列,并指定分配的新值。 这些值可以是字段的表达式或默认值。 设置默认值需要使用DEFAULT关键字。 该命令还可以使用WHERE子句来指定更新的条件和/或ORDER BY子句以特定顺序更新。
这篇文章我们来了解MariaDB中join语句用法,join语句是我们在使用数据库时非常基础的一个知识点,本文对新手学习MariaDB数据库会有帮助,下文有详细的介绍,有需要的朋友可以参考,接下来就跟随小编来一起学习一下吧!
MariaDB中数据库创建有什么条件,方法是什么? 在MariaDB中,具备创建或删除数据库权限的,一般是超级用户或管理员才能够实现。而要创建数据库,我们有两种方式可以选择,下面我们详细的了解看看。
MariaDB LEFT OUTER JOIN用于返回ON条件中指定的左侧表中的所有行,并仅返回满足连接条件的其他表中的行。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008