MySQL查询语法汇总

 更新时间:2020年08月11日 10:44:19   作者:MySQL技术  
这篇文章主要介绍了MySQL查询语法的汇总,帮助大家更好的理解和学习mysql,感兴趣的朋友可以了解下

前言:

本篇文章主要简介下MySQL中where,group by ,order by ,limit,join,union ,union all,子表等查询语法。

测试数据准备

create table emp (  empno numeric(4) not null,  ename varchar(10),  job varchar(9),  mgr numeric(4),  hiredate datetime,  sal numeric(7, 2),  comm numeric(7, 2),  deptno numeric(2));
create table dept (  deptno numeric(2),  dname varchar(14),  loc varchar(13));
create table salgrade (  grade numeric,  losal numeric,  hisal numeric);
insert into dept values (10, 'ACCOUNTING', 'NEW YORK');insert into dept values (20, 'RESEARCH', 'DALLAS');insert into dept values (30, 'SALES', 'CHICAGO');insert into dept values (40, 'OPERATIONS', 'BOSTON');
insert into salgrade values (1, 700, 1200);insert into salgrade values (2, 1201, 1400);insert into salgrade values (3, 1401, 2000);insert into salgrade values (4, 2001, 3000);insert into salgrade values (5, 3001, 9999);
insert into emp values (7369, 'SMITH', 'CLERK', 7902, '1980-12-17', 800, null, 20);insert into emp values (7499, 'ALLEN', 'SALESMAN', 7698, '1981-02-20', 1600, 300, 30);insert into emp values (7521, 'WARD', 'SALESMAN', 7698, '1981-02-22', 1250, 500, 30);insert into emp values (7566, 'JONES', 'MANAGER', 7839, '1981-04-02', 2975, null, 20);insert into emp values (7654, 'MARTIN', 'SALESMAN', 7698, '1981-09-28', 1250, 1400, 30);insert into emp values (7698, 'BLAKE', 'MANAGER', 7839, '1981-05-01', 2850, null, 30);insert into emp values (7782, 'CLARK', 'MANAGER', 7839, '1981-06-09', 2450, null, 10);insert into emp values (7788, 'SCOTT', 'ANALYST', 7566, '1982-12-09', 3000, null, 20);insert into emp values (7839, 'KING', 'PRESIDENT', null, '1981-11-17', 5000, null, 10);insert into emp values (7844, 'TURNER', 'SALESMAN', 7698, '1981-09-08', 1500, 0, 30);insert into emp values (7876, 'ADAMS', 'CLERK', 7788, '1983-01-12', 1100, null, 20);insert into emp values (7900, 'JAMES', 'CLERK', 7698, '1981-12-03', 950, null, 30);insert into emp values (7902, 'FORD', 'ANALYST', 7566, '1981-12-03', 3000, null, 20);insert into emp values (7934, 'MILLER', 'CLERK', 7782, '1982-01-23', 1300, null, 10);

1.模糊查询

mysql> select * from emp where ename like '%S%'; +-------+-------+---------+------+---------------------+---------+------+--------+| empno | ename | job   | mgr | hiredate      | sal   | comm | deptno |+-------+-------+---------+------+---------------------+---------+------+--------+| 7369 | SMITH | CLERK  | 7902 | 1980-12-17 00:00:00 | 800.00 | NULL |   20 || 7566 | JONES | MANAGER | 7839 | 1981-04-02 00:00:00 | 2975.00 | NULL |   20 || 7788 | SCOTT | ANALYST | 7566 | 1982-12-09 00:00:00 | 3000.00 | NULL |   20 || 7876 | ADAMS | CLERK  | 7788 | 1983-01-12 00:00:00 | 1100.00 | NULL |   20 || 7900 | JAMES | CLERK  | 7698 | 1981-12-03 00:00:00 | 950.00 | NULL |   30 |+-------+-------+---------+------+---------------------+---------+------+--------+5 rows in set (0.00 sec)
mysql> select * from emp where ename like 'S%'; +-------+-------+---------+------+---------------------+---------+------+--------+| empno | ename | job   | mgr | hiredate      | sal   | comm | deptno |+-------+-------+---------+------+---------------------+---------+------+--------+| 7369 | SMITH | CLERK  | 7902 | 1980-12-17 00:00:00 | 800.00 | NULL |   20 || 7788 | SCOTT | ANALYST | 7566 | 1982-12-09 00:00:00 | 3000.00 | NULL |   20 |+-------+-------+---------+------+---------------------+---------+------+--------+2 rows in set (0.01 sec)
mysql> select * from emp where ename like '%S';+-------+-------+---------+------+---------------------+---------+------+--------+| empno | ename | job   | mgr | hiredate      | sal   | comm | deptno |+-------+-------+---------+------+---------------------+---------+------+--------+| 7566 | JONES | MANAGER | 7839 | 1981-04-02 00:00:00 | 2975.00 | NULL |   20 || 7876 | ADAMS | CLERK  | 7788 | 1983-01-12 00:00:00 | 1100.00 | NULL |   20 || 7900 | JAMES | CLERK  | 7698 | 1981-12-03 00:00:00 | 950.00 | NULL |   30 |+-------+-------+---------+------+---------------------+---------+------+--------+3 rows in set (0.00 sec)
mysql> select * from emp where ename like '_O%';+-------+-------+---------+------+---------------------+---------+------+--------+| empno | ename | job   | mgr | hiredate      | sal   | comm | deptno |+-------+-------+---------+------+---------------------+---------+------+--------+| 7566 | JONES | MANAGER | 7839 | 1981-04-02 00:00:00 | 2975.00 | NULL |   20 || 7902 | FORD | ANALYST | 7566 | 1981-12-03 00:00:00 | 3000.00 | NULL |   20 |+-------+-------+---------+------+---------------------+---------+------+--------+2 rows in set (0.00 sec)

总结:%表示任意0个或多个字符,可匹配任意类型和长度的字符;_表示任意单个字符,匹配单个任意字符。

2.排序

mysql> select * from emp order by sal;+-------+--------+-----------+------+---------------------+---------+---------+--------+| empno | ename | job    | mgr | hiredate      | sal   | comm  | deptno |+-------+--------+-----------+------+---------------------+---------+---------+--------+| 7369 | SMITH | CLERK   | 7902 | 1980-12-17 00:00:00 | 800.00 |  NULL |   20 || 7900 | JAMES | CLERK   | 7698 | 1981-12-03 00:00:00 | 950.00 |  NULL |   30 || 7876 | ADAMS | CLERK   | 7788 | 1983-01-12 00:00:00 | 1100.00 |  NULL |   20 || 7521 | WARD  | SALESMAN | 7698 | 1981-02-22 00:00:00 | 1250.00 | 500.00 |   30 || 7654 | MARTIN | SALESMAN | 7698 | 1981-09-28 00:00:00 | 1250.00 | 1400.00 |   30 || 7934 | MILLER | CLERK   | 7782 | 1982-01-23 00:00:00 | 1300.00 |  NULL |   10 || 7844 | TURNER | SALESMAN | 7698 | 1981-09-08 00:00:00 | 1500.00 |  0.00 |   30 || 7499 | ALLEN | SALESMAN | 7698 | 1981-02-20 00:00:00 | 1600.00 | 300.00 |   30 || 7782 | CLARK | MANAGER  | 7839 | 1981-06-09 00:00:00 | 2450.00 |  NULL |   10 || 7698 | BLAKE | MANAGER  | 7839 | 1981-05-01 00:00:00 | 2850.00 |  NULL |   30 || 7566 | JONES | MANAGER  | 7839 | 1981-04-02 00:00:00 | 2975.00 |  NULL |   20 || 7788 | SCOTT | ANALYST  | 7566 | 1982-12-09 00:00:00 | 3000.00 |  NULL |   20 || 7902 | FORD  | ANALYST  | 7566 | 1981-12-03 00:00:00 | 3000.00 |  NULL |   20 || 7839 | KING  | PRESIDENT | NULL | 1981-11-17 00:00:00 | 5000.00 |  NULL |   10 |+-------+--------+-----------+------+---------------------+---------+---------+--------+14 rows in set (0.00 sec)
mysql> select * from emp order by sal asc;+-------+--------+-----------+------+---------------------+---------+---------+--------+| empno | ename | job    | mgr | hiredate      | sal   | comm  | deptno |+-------+--------+-----------+------+---------------------+---------+---------+--------+| 7369 | SMITH | CLERK   | 7902 | 1980-12-17 00:00:00 | 800.00 |  NULL |   20 || 7900 | JAMES | CLERK   | 7698 | 1981-12-03 00:00:00 | 950.00 |  NULL |   30 || 7876 | ADAMS | CLERK   | 7788 | 1983-01-12 00:00:00 | 1100.00 |  NULL |   20 || 7521 | WARD  | SALESMAN | 7698 | 1981-02-22 00:00:00 | 1250.00 | 500.00 |   30 || 7654 | MARTIN | SALESMAN | 7698 | 1981-09-28 00:00:00 | 1250.00 | 1400.00 |   30 || 7934 | MILLER | CLERK   | 7782 | 1982-01-23 00:00:00 | 1300.00 |  NULL |   10 || 7844 | TURNER | SALESMAN | 7698 | 1981-09-08 00:00:00 | 1500.00 |  0.00 |   30 || 7499 | ALLEN | SALESMAN | 7698 | 1981-02-20 00:00:00 | 1600.00 | 300.00 |   30 || 7782 | CLARK | MANAGER  | 7839 | 1981-06-09 00:00:00 | 2450.00 |  NULL |   10 || 7698 | BLAKE | MANAGER  | 7839 | 1981-05-01 00:00:00 | 2850.00 |  NULL |   30 || 7566 | JONES | MANAGER  | 7839 | 1981-04-02 00:00:00 | 2975.00 |  NULL |   20 || 7788 | SCOTT | ANALYST  | 7566 | 1982-12-09 00:00:00 | 3000.00 |  NULL |   20 || 7902 | FORD  | ANALYST  | 7566 | 1981-12-03 00:00:00 | 3000.00 |  NULL |   20 || 7839 | KING  | PRESIDENT | NULL | 1981-11-17 00:00:00 | 5000.00 |  NULL |   10 |+-------+--------+-----------+------+---------------------+---------+---------+--------+14 rows in set (0.00 sec)
mysql> select * from emp order by sal desc;+-------+--------+-----------+------+---------------------+---------+---------+--------+| empno | ename | job    | mgr | hiredate      | sal   | comm  | deptno |+-------+--------+-----------+------+---------------------+---------+---------+--------+| 7839 | KING  | PRESIDENT | NULL | 1981-11-17 00:00:00 | 5000.00 |  NULL |   10 || 7788 | SCOTT | ANALYST  | 7566 | 1982-12-09 00:00:00 | 3000.00 |  NULL |   20 || 7902 | FORD  | ANALYST  | 7566 | 1981-12-03 00:00:00 | 3000.00 |  NULL |   20 || 7566 | JONES | MANAGER  | 7839 | 1981-04-02 00:00:00 | 2975.00 |  NULL |   20 || 7698 | BLAKE | MANAGER  | 7839 | 1981-05-01 00:00:00 | 2850.00 |  NULL |   30 || 7782 | CLARK | MANAGER  | 7839 | 1981-06-09 00:00:00 | 2450.00 |  NULL |   10 || 7499 | ALLEN | SALESMAN | 7698 | 1981-02-20 00:00:00 | 1600.00 | 300.00 |   30 || 7844 | TURNER | SALESMAN | 7698 | 1981-09-08 00:00:00 | 1500.00 |  0.00 |   30 || 7934 | MILLER | CLERK   | 7782 | 1982-01-23 00:00:00 | 1300.00 |  NULL |   10 || 7521 | WARD  | SALESMAN | 7698 | 1981-02-22 00:00:00 | 1250.00 | 500.00 |   30 || 7654 | MARTIN | SALESMAN | 7698 | 1981-09-28 00:00:00 | 1250.00 | 1400.00 |   30 || 7876 | ADAMS | CLERK   | 7788 | 1983-01-12 00:00:00 | 1100.00 |  NULL |   20 || 7900 | JAMES | CLERK   | 7698 | 1981-12-03 00:00:00 | 950.00 |  NULL |   30 || 7369 | SMITH | CLERK   | 7902 | 1980-12-17 00:00:00 | 800.00 |  NULL |   20 |+-------+--------+-----------+------+---------------------+---------+---------+--------+14 rows in set (0.00 sec)

总结:order by排序默认按asc升序来排列也可指定desc降序排列

3.限制多少行

mysql> select * from emp limit 3;+-------+-------+----------+------+---------------------+---------+--------+--------+| empno | ename | job   | mgr | hiredate      | sal   | comm  | deptno |+-------+-------+----------+------+---------------------+---------+--------+--------+| 7369 | SMITH | CLERK  | 7902 | 1980-12-17 00:00:00 | 800.00 |  NULL |   20 || 7499 | ALLEN | SALESMAN | 7698 | 1981-02-20 00:00:00 | 1600.00 | 300.00 |   30 || 7521 | WARD | SALESMAN | 7698 | 1981-02-22 00:00:00 | 1250.00 | 500.00 |   30 |+-------+-------+----------+------+---------------------+---------+--------+--------+3 rows in set (0.00 sec)
mysql> select * from emp order by sal desc limit 3;+-------+-------+-----------+------+---------------------+---------+------+--------+| empno | ename | job    | mgr | hiredate      | sal   | comm | deptno |+-------+-------+-----------+------+---------------------+---------+------+--------+| 7839 | KING | PRESIDENT | NULL | 1981-11-17 00:00:00 | 5000.00 | NULL |   10 || 7902 | FORD | ANALYST  | 7566 | 1981-12-03 00:00:00 | 3000.00 | NULL |   20 || 7788 | SCOTT | ANALYST  | 7566 | 1982-12-09 00:00:00 | 3000.00 | NULL |   20 |+-------+-------+-----------+------+---------------------+---------+------+--------+3 rows in set (0.00 sec)

总结:limit限定显示前多少行,可与order by联合使用

4.聚合函

count() sum()函数用法:#1.各个部门的薪水和mysql> select deptno,sum(sal) from emp group by deptno;+--------+----------+| deptno | sum(sal) |+--------+----------+|   10 | 8750.00 ||   20 | 10875.00 ||   30 | 9400.00 |+--------+----------+3 rows in set (0.01 sec)
#2.group by字段必须出现在select字段后面  各个部门的各个岗位的薪水和mysql> select deptno,job, sum(sal) from emp group by deptno ,job;+--------+-----------+----------+| deptno | job    | sum(sal) |+--------+-----------+----------+|   10 | CLERK   | 1300.00 ||   10 | MANAGER  | 2450.00 ||   10 | PRESIDENT | 5000.00 ||   20 | ANALYST  | 6000.00 ||   20 | CLERK   | 1900.00 ||   20 | MANAGER  | 2975.00 ||   30 | CLERK   |  950.00 ||   30 | MANAGER  | 2850.00 ||   30 | SALESMAN | 5600.00 |+--------+-----------+----------+9 rows in set (0.01 sec)
#3.having  薪水和>5000的各个部门的各个岗位mysql> select deptno,job, sum(sal)   -> from emp   -> group by deptno ,job  -> having sum(sal)>5000; +--------+----------+----------+| deptno | job   | sum(sal) |+--------+----------+----------+|   20 | ANALYST | 6000.00 ||   30 | SALESMAN | 5600.00 |+--------+----------+----------+2 rows in set (0.00 sec)#4.常用组合where order limit select deptno,job, sum(sal) as sum_salfrom emp where job='SALESMAN'group by deptno ,jobhaving sum(sal)>5000 order by sum(sal) desc limit 1;

下面介绍下join及union的用法
数据准备:

create table testa(aid int,aname varchar(40));
create table testb(bid int,bname varchar(40),age int);
insert into testa values(1,'xiaoming');insert into testa values(2,'LY');insert into testa values(3,'KUN');insert into testa values(4,'ZIDONG');insert into testa values(5,'HB');

insert into testb values(1,'xiaoming',10);insert into testb values(2,'LY',100);insert into testb values(3,'KUN',200);insert into testb values(4,'ZIDONG',110);insert into testb values(6,'niu',120);insert into testb values(7,'meng',130);insert into testb values(8,'mi',170);

5.left join

mysql> select  -> a.aid,a.aname,  -> b.bid,b.bname,b.age  -> from testa as a  -> left join testb as b on a.aid=b.bid; +------+----------+------+----------+------+| aid | aname  | bid | bname  | age |+------+----------+------+----------+------+|  1 | xiaoming |  1 | xiaoming |  10 ||  2 | LY    |  2 | LY    | 100 ||  3 | KUN   |  3 | KUN   | 200 ||  4 | ZIDONG  |  4 | ZIDONG  | 110 ||  5 | HB    | NULL | NULL   | NULL |+------+----------+------+----------+------+5 rows in set (0.00 sec)

总结:a left join b  a表全,用b表去匹配a表LEFT JOIN 关键字会从左表 (a) 那里返回所有的行,即使在右表 (b) 中没有匹配的行,匹配不到的列用NULL代替

6.right join

mysql> select  -> a.aid,a.aname,  -> b.bid,b.bname,b.age  -> from testa as a  -> right join testb as b on a.aid=b.bid;+------+----------+------+----------+------+| aid | aname  | bid | bname  | age |+------+----------+------+----------+------+|  1 | xiaoming |  1 | xiaoming |  10 ||  2 | LY    |  2 | LY    | 100 ||  3 | KUN   |  3 | KUN   | 200 ||  4 | ZIDONG  |  4 | ZIDONG  | 110 || NULL | NULL   |  6 | niu   | 120 || NULL | NULL   |  7 | meng   | 130 || NULL | NULL   |  8 | mi    | 170 |+------+----------+------+----------+------+7 rows in set (0.00 sec)

总结:a right join b  b表全,用a表去匹配b表RIGHT JOIN 关键字会右表 (b) 那里返回所有的行,即使在左表 (a) 中没有匹配的行,匹配不到的列用NULL代替

7.inner join

mysql> select  -> a.aid,a.aname,  -> b.bid,b.bname,b.age  -> from testa as a  -> inner join testb as b on a.aid=b.bid; +------+----------+------+----------+------+| aid | aname  | bid | bname  | age |+------+----------+------+----------+------+|  1 | xiaoming |  1 | xiaoming |  10 ||  2 | LY    |  2 | LY    | 100 ||  3 | KUN   |  3 | KUN   | 200 ||  4 | ZIDONG  |  4 | ZIDONG  | 110 |+------+----------+------+----------+------+4 rows in set (0.00 sec)
mysql> select  -> a.aid,a.aname,  -> b.bid,b.bname,b.age  -> from testa as a  -> join testb as b on a.aid=b.bid; +------+----------+------+----------+------+| aid | aname  | bid | bname  | age |+------+----------+------+----------+------+|  1 | xiaoming |  1 | xiaoming |  10 ||  2 | LY    |  2 | LY    | 100 ||  3 | KUN   |  3 | KUN   | 200 ||  4 | ZIDONG  |  4 | ZIDONG  | 110 |+------+----------+------+----------+------+4 rows in set (0.00 sec)

总结:inner join 与join 效果一样在表中存在至少一个匹配时,INNER JOIN 关键字返回行

8.union与union all

mysql> select aid,aname from testa  -> union  -> select bid,bname from testb;+------+----------+| aid | aname  |+------+----------+|  1 | xiaoming ||  2 | LY    ||  3 | KUN   ||  4 | ZIDONG  ||  5 | HB    ||  6 | niu   ||  7 | meng   ||  8 | mi    |+------+----------+8 rows in set (0.01 sec)
mysql> select aid,aname from testa  -> union all  -> select bid,bname from testb;+------+----------+| aid | aname  |+------+----------+|  1 | xiaoming ||  2 | LY    ||  3 | KUN   ||  4 | ZIDONG  ||  5 | HB    ||  1 | xiaoming ||  2 | LY    ||  3 | KUN   ||  4 | ZIDONG  ||  6 | niu   ||  7 | meng   ||  8 | mi    |+------+----------+12 rows in set (0.00 sec)

总结:union 会去重 union all不去重

以上就是MySQL查询语法汇总的详细内容,更多关于MySQL查询语法的资料请关注脚本之家其它相关文章!

相关文章

  • 将旧版MySQL替换为8.0及以上版本保姆级教学

    将旧版MySQL替换为8.0及以上版本保姆级教学

    在部署项目的时候MySQL就会报错,这个时候就要换MySQL的版本了,这篇文章主要给大家介绍了关于将旧版MySQL替换为8.0及以上版本的相关资料,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2024-05-05
  • MySQL Json类型字段IN查询分组优化

    MySQL Json类型字段IN查询分组优化

    这篇文章主要为大家介绍了MySQL Json类型字段IN查询分组优化,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-08-08
  • MySQL 使用 SSL 连接配置详解

    MySQL 使用 SSL 连接配置详解

    本文给大家分享的是如何配置MySQL支持SSL连接方式的方法以及在docker中配置的具体案例,有需要的小伙伴可以参考下
    2016-12-12
  • 浅谈MySQL user权限表

    浅谈MySQL user权限表

    MySQL 在安装时会自动创建一个名为 mysql 的数据库,mysql 数据库中存储的都是用户权限表。本文就详细的介绍一下MySQL user权限表 ,感兴趣的可以了解一下
    2021-06-06
  • linux下mysql乱码问题的解决方案

    linux下mysql乱码问题的解决方案

    今天小编就为大家分享一篇关于linux下mysql乱码问题的解决方案,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-03-03
  • MySQL FIND_IN_SET函数的使用场景

    MySQL FIND_IN_SET函数的使用场景

    本文介绍了MySQL中FIND_IN_SET函数的基本语法和使用场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2025-01-01
  • mysql表名忽略大小写配置方法详解

    mysql表名忽略大小写配置方法详解

    下面小编就为大家带来一篇mysql表名忽略大小写配置方法详解。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-03-03
  • MySQL 数据库常用命令 简单超级实用版

    MySQL 数据库常用命令 简单超级实用版

    MySQL 数据库常用命令,都是一些比较基础的东西,更多的命令可以查看相关文章里面的文字。
    2010-07-07
  • CentOS 7 安装Percona Server+Mysql

    CentOS 7 安装Percona Server+Mysql

    这篇文章主要介绍了CentOS 7 安装Percona Server+Mysql的相关资料,需要的朋友可以参考下
    2018-11-11
  • MySQL中的间隙锁代码示例讲解

    MySQL中的间隙锁代码示例讲解

    锁是mysql提供的一种保证不同事务读写隔离的重要措施,通过锁机制可以有效提升决多线程下并发处理事务能力,不同的锁划分对应着不同的使用场景,本文来深入探讨一下mysql的另一种容易被忽视的锁,即间隙锁,以及与之相关的相关问题,需要的朋友可以参考下
    2023-08-08

最新评论