MariaDB中UNION运算符用来做什么,具体怎么用
Admin 2022-06-24 群英技术资讯 1260 次浏览
这篇文章主要介绍“MariaDB中UNION运算符用来做什么,具体怎么用”的相关知识,下面会通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MariaDB中UNION运算符用来做什么,具体怎么用”文章能帮助大家解决问题。在MariaDB数据库中,UNION运算符用于组合两个或更多SELECT语句的结果集。它删除各种SELECT语句之间的重复行。
语法
SELECT expression1, expression2, ... expression_n
FROM tables
[WHERE conditions]
UNION [DISTINCT]
SELECT expression1, expression2, ... expression_n
FROM tables
[WHERE conditions];
注意:
UNION运算符中的每个SELECT语句在具有相似数据类型的结果集中必须具有相同数量的字段。
下面来看一个从多个SELECT语句返回一个字段的UNION运算符的例子。(两个表具有相同的公共字段)。
假设有两张表: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;
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,'陈小祥','上海','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 | 陈小祥 | 上海 | 2013-06-07 |
| 2 | 张天经 | 广州 | 2013-08-08 |
| 3 | 李四光 | 三亚 | 2014-09-07 |
+------------+--------+---------+----------------+
3 rows in set (0.08 sec)
假设现在要查询所有学生和老师的姓名,以及他们的地址,可参考以下查询语句 -
SELECT student_name AS name, student_address as address
FROM Students
UNION
SELECT name,address
FROM teachers;
执行上面查询语句,得到以下结果 -
MariaDB [testdb]> SELECT student_name AS name, student_address as address
-> FROM Students
-> UNION
-> SELECT name,address
-> FROM teachers;
+---------+-----------+
| name | address |
+---------+-----------+
| Maxsu | Haikou |
| JMaster | Beijing |
| Mahesh | Guangzhou |
| Kobe | Shanghai |
| Blaba | Shenzhen |
| 陈小祥 | 上海 |
| 张天经 | 广州 |
| 李四光 | 三亚 |
+---------+-----------+
8 rows in set (0.05 sec)
它显示了两个表中并删除重复的name列的值。
使用ORDER BY子句的UNION运算符从两个表中检索多个列。参考以下语句 -
SELECT student_id, student_name
FROM Students
WHERE student_name = 'Maxsu'
UNION
SELECT teacher_id, address
FROM teachers
WHERE teacher_id > 1
ORDER BY 1;
执行上面示例代码,得到以下结果 -
MariaDB [testdb]> SELECT student_id, student_name
-> FROM Students
-> WHERE student_name = 'Maxsu'
-> UNION
-> SELECT teacher_id, address
-> FROM teachers
-> WHERE teacher_id > 1
-> ORDER BY 1;
+------------+--------------+
| student_id | student_name |
+------------+--------------+
| 1 | Maxsu |
| 2 | 广州 |
| 3 | 三亚 |
+------------+--------------+
3 rows in set (0.00 sec)
具有不同列名的表之间的UNION:
(SELECT e_name AS name, email FROM employees)
UNION
(SELECT c_name AS name, email FROM customers);
指定UNION的全局顺序并限制总行数:
(SELECT name, email FROM employees)
UNION
(SELECT name, email FROM customers)
ORDER BY name LIMIT 10;
添加一个常数行:
(SELECT 'John Doe' AS name, 'john.doe@example.net' AS email)
UNION
(SELECT name, email FROM customers);
不同的类型:
SELECT CAST('x' AS CHAR(1)) UNION SELECT REPEAT('y',4);
+----------------------+
| CAST('x' AS CHAR(1)) |
+----------------------+
| x |
| yyyy |
+----------------------+
按照每个SELECT使用排序列的顺序返回结果:
(SELECT 1 AS sort_column, e_name AS name, email FROM employees)
UNION
(SELECT 2, c_name AS name, email FROM customers) ORDER BY sort_column;
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
篇文章给大家分享的是MariaDB中where子句的相关内容,对于where子句有什么作用及其使用,下文有都有介绍,对大家学习MariaDB数据库有帮助,有需要的朋友可以学习参考,接下来就跟随小编一起了解看看吧。
数据作为业务和操作的基础,并且具有各种可能的威胁(例如,攻击者,系统故障,不良升级和维护错误),备份仍然至关重要。 这些备份采用多种形式,并且存在许多选项用于在这些过程中使用更宽泛的选项来创建它们。 要记住的重要事情是数据库类型,关键信息和所涉及的结构。 此信息确定您的最佳选择。
在MariaDB数据库中,ORDER BY子句用于按升序或降序对结果集中的记录进行排序。
这篇文章给大家分享的是MariaDB中order by子句的相关内容。ORDER BY子句是对查询的结果进行排序,小编觉得挺实用的,因此分享给大家做个参考,文中介绍得很详细,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。
WHERE子句提供了一种在操作使用完全匹配时检索数据的方法。 在需要具有共享特征的多个结果的情况下,LIKE子句适应宽模式匹配。LIKE子句测试模式匹配,返回true或false。 用于比较的模式接受以下通配符:"%",其匹配字符数(0或更多); 和"_",它匹配单个字符
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008