MySQL查询语法汇总

论坛 期权论坛 脚本     
niminba   2021-5-23 04:59   759   0

前言:

本篇文章主要简介下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 | 7698sS#sR3C2&WB6V2Т3"'ZjX{x6V7NZj"YNK:zyNYNK[)~KyNjkNY(7wC6V7BFWF7V6g&w&'FWFFWF7V64$3U"#CS$U4DTS#5Bc#4$#U"#sR34$S3U"#S344Sc&WB6V2Т32fjkNY(wCSyNYNK:zyNYNK[)~K7wC6V7BFWF7V6wCg&wCw&'FWFwCf7V6fwCSFWF7V6#5Bc344Sc"&WB6V23ByJ{NYvW&R"B6V7BFWF7V627V6&vW&R44&'FWFf7V6fwCS"'7V6FW62B&SУFcУK{NyJk9S#Юi[hXxnZH~Уb673&66У&R673''W67ò#Ц7&VFRF&FW7FBRf&6"CЦ7&VFRF&FW7F"&B&Rf&6"CvRЦ'BFW7FfW2rr'BFW7FfW2"r'BFW7FfW22T'BFW7FfW2BD'BFW7FfW2R"rРЦ'BFW7F"fW2rr'BFW7F"fW2"r'BFW7F"fW22T#'BFW7F"fW2BD'BFW7F"fW2br#'BFW7F"fW2r3'BFW7F"fW2rsУ&SУFcУG&RgBУb673&66У&R673''W67ò#Ц7wC6V7BwCBwC"BRwCg&W7F2wCgBFW7F"2"CCBR&B&RvRrr""2T2T#BDBDR"R&WB6V2&SУFcУ{>gB"fXZ.XXeBX[>J~KKn*>xhiyNXKYX"K*iXXNXXyNX~yJ>iУG&bvBУb673&66У&R673''W67ò#Ц7wC6V7BwCBwC"BRwCg&W7F2wC&vBFW7F"2"CCBR&B&RvRrr""2T2T#BDBDb#r3sr&WB6V2&SУFcУ{>&vB"f.XZXX$tBX[>J~KX"*>xhiyNXKY[znK*iXXNXXyNX~yJ>iУG&rУb673&66У&R673''W67ò#Ц7wC6V7BwCBwC"BRwCg&W7F2wC"FW7F"2"CCBR&B&RvRrr""2T2T#BDBDB&WB6V2Ц7wC6V7BwCBwC"BRwCg&W7F2wCFW7F"2"CCBR&B&RvRrr""2T2T#BDBDB&WB6V2&SУFcУ{>KXij~YKY{>[	KKXX{nX[>J~G&7G&Уb673&66У&R673''W67ò#Ц7wC6V7BBRg&W7FwCVwC6V7B&BRg&W7F#BRr"2TBDR"br&WB6V2Ц7wC6V7BBRg&W7FwCVwC6V7B&BRg&W7F#BRr"2TBDR"r"2TBDbr"&WB6V2&SУFcУ{>XxVKx^K[ik~hyNXh^ZiNZIX[>K5yNXNiik:zKX[nZX[>ih~z
分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:1060120
帖子:212021
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP