热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

查询语句_MySQL简单查询语句练习

篇首语:本文由编程笔记#小编为大家整理,主要介绍了MySQL简单查询语句练习相关的知识,希望对你有一定的参考价值。数据查询语法(

篇首语:本文由编程笔记#小编为大家整理,主要介绍了MySQL简单查询语句练习相关的知识,希望对你有一定的参考价值。



数据查询语法(DQL

  DQL就是数据查询语言,数据库执行DQL语句不会对数据进行改变,而是让数据库发送结果集给客户端。

语法:

SELECT selection_list /*要查询的列名称*/

  FROM table_list /*要查询的表名称*/

  WHERE condition /*行条件*/

  GROUP BY grouping_columns /*对结果分组*/

  HAVING condition /*分组后的行条件*/

  ORDER BY sorting_columns /*对结果分组*/

  LIMIT offset_start, row_count /*结果限定*/

 

创建名:

学生表:stu






























字段名称


字段类型


说明


sid


char(6)


学生学号


sname


varchar(50)


学生姓名


age


int


学生年龄


gender


varchar(50)


学生性别


 











CREATE TABLE stu (

sid CHAR(6),

sname VARCHAR(50),

age INT,

gender VARCHAR(50)

);


INSERT INTO stu VALUES(‘S_1001‘, ‘liuYi‘, 35, ‘male‘);

INSERT INTO stu VALUES(‘S_1002‘, ‘chenEr‘, 15, ‘female‘);

INSERT INTO stu VALUES(‘S_1003‘, ‘zhangSan‘, 95, ‘male‘);

INSERT INTO stu VALUES(‘S_1004‘, ‘liSi‘, 65, ‘female‘);

INSERT INTO stu VALUES(‘S_1005‘, ‘wangWu‘, 55, ‘male‘);

INSERT INTO stu VALUES(‘S_1006‘, ‘zhaoLiu‘, 75, ‘female‘);

INSERT INTO stu VALUES(‘S_1007‘, ‘sunQi‘, 25, ‘male‘);

INSERT INTO stu VALUES(‘S_1008‘, ‘zhouBa‘, 45, ‘female‘);

INSERT INTO stu VALUES(‘S_1009‘, ‘wuJiu‘, 85, ‘male‘);

INSERT INTO stu VALUES(‘S_1010‘, ‘zhengShi‘, 5, ‘female‘);

INSERT INTO stu VALUES(‘S_1011‘, ‘xxx‘, NULL, NULL);


 

雇员表:emp


















































字段名称


字段类型


说明


empno


int


员工编号


ename


varchar(50)


员工姓名


job


varchar(50)


员工工作


mgr


int


领导编号


hiredate


date


入职日期


sal


decimal(7,2)


月薪


comm


decimal(7,2)


奖金


deptno


int


部分编号


 











CREATE TABLE emp(

empno INT,

ename VARCHAR(50),

job VARCHAR(50),

mgr INT,

hiredate DATE,

sal DECIMAL(7,2),

comm decimal(7,2),

deptno INT

) ;


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,‘1987-04-19‘,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,‘1987-05-23‘,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);


 

部分表:dept

























字段名称


字段类型


说明


deptno


int


部分编码


dname


varchar(50)


部分名称


loc


varchar(50)


部分所在地点


 











CREATE TABLE dept(

deptno INT,

dname varchar(14),

loc varchar(13)

);


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‘);


 


1 基础查询

1.1 查询所有列

SELECT * FROM stu;

 

1.2 查询指定列

SELECT sid, sname, age FROM stu;

 


2 条件查询

2.1 条件查询介绍

条件查询就是在查询时给出WHERE子句,在WHERE子句中可以使用如下运算符及关键字:

l =!=<><<=>>=

l BETWEEN…AND;

l IN(set)

l IS NULL

l AND

l OR

l NOT

 

2.2 查询性别为女,并且年龄50的记录

  SELECT * FROM stu

WHERE gender=‘female‘ AND ge<50;

 

2.3 查询学号为S_1001,或者姓名为liSi的记录

SELECT * FROM stu

WHERE sid =‘S_1001‘ OR sname=‘liSi‘;

 

2.4 查询学号为S_1001S_1002S_1003的记录

SELECT * FROM stu

WHERE sid IN (‘S_1001‘,‘S_1002‘,‘S_1003‘);

 

2.5 查询学号不是S_1001S_1002S_1003的记录

SELECT * FROM tab_student

WHERE s_number NOT IN (‘S_1001‘,‘S_1002‘,‘S_1003‘);

 

2.6 查询年龄为null的记录

SELECT * FROM stu

WHERE age IS NULL;

 

2.7 查询年龄在2040之间的学生记录

SELECT *

FROM stu

WHERE age>=20 AND age<=40;

或者

SELECT *

FROM stu

WHERE age BETWEEN 20 AND 40;

 

2.8 查询性别非男的学生记录

SELECT *

FROM stu

WHERE gender!=‘male‘;

或者

SELECT *

FROM stu

WHERE gender<>‘male‘;

或者

SELECT *

FROM stu

WHERE NOT gender=‘male‘;

 

2.9 查询姓名不为null的学生记录

SELECT *

FROM stu

WHERE NOT sname IS NULL;

或者

SELECT *

FROM stu

WHERE sname IS NOT NULL;

 


3 模糊查询

当想查询姓名中包含a字母的学生时就需要使用模糊查询了。模糊查询需要使用关键字LIKE

3.1 查询姓名由5个字母构成的学生记录

SELECT *

FROM stu

WHERE sname LIKE ‘_____‘;

模糊查询必须使用LIKE关键字。其中 “_”匹配任意一个字母,5个“_”表示5个任意字母。

 

3.2 查询姓名由5个字母构成,并且第5个字母为“i”的学生记录

SELECT *

FROM stu

WHERE sname LIKE ‘____i‘;

 

3.3 查询姓名以“z”开头的学生记录

SELECT *

FROM stu

WHERE sname LIKE ‘z%‘;

其中%”匹配0~n个任何字母。

 

3.4 查询姓名中第2个字母为“i”的学生记录

SELECT *

FROM stu

WHERE sname LIKE ‘_i%‘;

 

3.5 查询姓名中包含“a”字母的学生记录

SELECT *

FROM stu

WHERE sname LIKE ‘%a%‘;

 


4 字段控制查询

4.1 去除重复记录

去除重复记录(两行或两行以上记录中系列的上的数据都相同),例如emp表中sal字段就存在相同的记录。当只查询emp表的sal字段时,那么会出现重复记录,那么想去除重复记录,需要使用DISTINCT

SELECT DISTINCT sal FROM emp;

 

4.2 查看雇员的月薪与佣金之和

  因为salcomm两列的类型都是数值类型,所以可以做加运算。如果salcomm中有一个字段不是数值类型,那么会出错。

SELECT *,sal+comm FROM emp;

 

comm列有很多记录的值为NULL,因为任何东西与NULL相加结果还是NULL,所以结算结果可能会出现NULL。下面使用了把NULL转换成数值0的函数IFNULL

SELECT *,sal+IFNULL(comm,0) FROM emp;

 

4.3 给列名添加别名

在上面查询中出现列名为sal+IFNULL(comm,0),这很不美观,现在我们给这一列给出一个别名,为total

SELECT *, sal+IFNULL(comm,0) AS total FROM emp;

给列起别名时,是可以省略AS关键字的:

SELECT *,sal+IFNULL(comm,0) total FROM emp;

 


5 排序

5.1 查询所有学生记录,按年龄升序排序

SELECT *

FROM stu

ORDER BY sage ASC;

或者

SELECT *

FROM stu

ORDER BY sage;

 

5.2 查询所有学生记录,按年龄降序排序

SELECT *

FROM stu

ORDER BY age DESC;

 

5.3 查询所有雇员,按月薪降序排序,如果月薪相同时,按编号升序排序

SELECT * FROM emp

ORDER BY sal DESC,empno ASC;

 


6 聚合函数

聚合函数是用来做纵向运算的函数:

l COUNT():统计指定列不为NULL的记录行数;

l MAX():计算指定列的最大值,如果指定列是字符串类型,那么使用字符串排序运算;

l MIN():计算指定列的最小值,如果指定列是字符串类型,那么使用字符串排序运算;

l SUM():计算指定列的数值和,如果指定列类型不是数值类型,那么计算结果为0

l AVG():计算指定列的平均值,如果指定列类型不是数值类型,那么计算结果为0

 

6.1 COUNT

当需要纵向统计时可以使用COUNT()

查询emp表中记录数:

SELECT COUNT(*) AS cnt FROM emp;

 

查询emp表中有佣金的人数:

SELECT COUNT(comm) cnt FROM emp;

注意,因为count()函数中给出的是comm列,那么只统计comm列非NULL的行数。

 

查询emp表中月薪大于2500的人数:

SELECT COUNT(*) FROM emp

WHERE sal > 2500;

 

统计月薪与佣金之和大于2500元的人数:

SELECT COUNT(*) AS cnt FROM emp WHERE sal+IFNULL(comm,0) > 2500;

 

l 查询有佣金的人数,以及有领导的人数:

SELECT COUNT(comm), COUNT(mgr) FROM emp;

 

6.2 SUMAVG

当需要纵向求和时使用sum()函数。

l 查询所有雇员月薪和:

SELECT SUM(sal) FROM emp;

 

l 查询所有雇员月薪和,以及所有雇员佣金和:

SELECT SUM(sal), SUM(comm) FROM emp;

 

查询所有雇员月薪+佣金和:

SELECT SUM(sal+IFNULL(comm,0)) FROM emp;

 

l 统计所有员工平均工资:

SELECT SUM(sal), COUNT(sal) FROM emp;

或者

SELECT AVG(sal) FROM emp;

 

6.3 MAXMIN

l 查询最高工资和最低工资:

SELECT MAX(sal), MIN(sal) FROM emp;

 


7 分组查询

 

当需要分组查询时需要使用GROUP BY子句,例如查询每个部门的工资和,这说明要使用部分来分组。

 

7.1 分组查询

l 查询每个部门的部门编号和每个部门的工资和:

SELECT deptno, SUM(sal)

FROM emp

GROUP BY deptno;

 

l 查询每个部门的部门编号以及每个部门的人数:

SELECT deptno,COUNT(*)

FROM emp

GROUP BY deptno;

 

查询每个部门的部门编号以及每个部门工资大于1500的人数:

SELECT deptno,COUNT(*)

FROM emp

WHERE sal>1500

GROUP BY deptno;

 

7.2 HAVING子句

查询工资总和大于9000的部门编号以及工资和:

SELECT deptno, SUM(sal)

FROM emp

GROUP BY deptno

HAVING SUM(sal) > 9000;

  

注:havingwhere的区别:

1.having是在分组后对数据进行过滤.

  where是在分组前对数据进行过滤

 

2.having后面可以使用分组函数(统计函数)

          where后面不可以使用分组函数。

WHERE是对分组前记录的条件,如果某行记录没有满足WHERE子句的条件,那么这行记录不会参加分组;而HAVING是对分组后数据的约束。

 


8 LIMIT

LIMIT用来限定查询结果的起始行,以及总行数。

 

8.1 查询5行记录,起始行从0开始

SELECT * FROM emp LIMIT 0, 5;

 

注意,起始行从0开始,即第一行开始!

 

8.2 查询10行记录,起始行从3开始

SELECT * FROM emp LIMIT 3, 10;

 

8.3 分页查询

如果一页记录为10条,希望查看第3页记录应该怎么查呢?

第一页记录起始行为0,一共查询10行;

第二页记录起始行为10,一共查询10行;

第三页记录起始行为20,一共查询10行;

8.3 分页查询

查询语句书写顺序:select – from- where- group by- having- order by-limit

查询语句执行顺序:from - where -group by - having - select - order by-limit

 


推荐阅读
  • 本文详细介绍如何在SSM(Spring + Spring MVC + MyBatis)框架中实现分页功能。包括分页的基本概念、数据准备、前端分页栏的设计与实现、后端分页逻辑的编写以及最终的测试步骤。 ... [详细]
  • 本文深入探讨了MySQL中的高级特性,包括索引机制、锁的使用及管理、以及如何利用慢查询日志优化性能。适合有一定MySQL基础的读者进一步提升技能。 ... [详细]
  • 本文由公众号【数智物语】(ID: decision_engine)发布,关注获取更多干货。文章探讨了从数据收集到清洗、建模及可视化的全过程,介绍了41款实用工具,旨在帮助数据科学家和分析师提升工作效率。 ... [详细]
  • Java连接MySQL数据库的方法及测试示例
    本文详细介绍了如何安装MySQL数据库,并通过Java编程语言实现与MySQL数据库的连接,包括环境搭建、数据库创建以及简单的查询操作。 ... [详细]
  • 本文探讨了如何使用Scrapy框架构建高效的数据采集系统,以及如何通过异步处理技术提升数据存储的效率。同时,文章还介绍了针对不同网站采用的不同采集策略。 ... [详细]
  • 我在尝试将组合框转换为具有自动完成功能时遇到了一个问题,即页面上的列表框也被转换成了自动完成下拉框,而不是保持原有的多选列表框形式。 ... [详细]
  • 本文详细介绍了如何使用Linux下的mysqlshow命令来查询MySQL数据库的相关信息,包括数据库、表以及字段的详情。通过本文的学习,读者可以掌握mysqlshow命令的基本语法及其常用选项。 ... [详细]
  • Docker基础入门与环境配置指南
    本文介绍了Docker——一款用Go语言编写的开源应用程序容器引擎。通过Docker,用户能够将应用及其依赖打包进容器内,实现高效、轻量级的虚拟化。容器之间采用沙箱机制,确保彼此隔离且资源消耗低。 ... [详细]
  • Hadoop MapReduce 实战案例:手机流量使用统计分析
    本文通过一个具体的Hadoop MapReduce案例,详细介绍了如何利用MapReduce框架来统计和分析手机用户的流量使用情况,包括上行和下行流量的计算以及总流量的汇总。 ... [详细]
  • 在使用mybatis进行mapper.xml测试的时候发生必须为元素类型“mapper”声明属性“namespace”的错误项目目录结构UserMapper和UserMappe ... [详细]
  • Excel技巧:单元格中显示公式而非结果的解决方法
    本文探讨了在Excel中如何通过简单的方法解决单元格显示公式而非计算结果的问题,包括使用快捷键和调整单元格格式两种方法。 ... [详细]
  • 【MySQL】frm文件解析
    官网说明:http:dev.mysql.comdocinternalsenfrm-file-format.htmlfrm是MySQL表结构定义文件,通常frm文件是不会损坏的,但是如果 ... [详细]
  • 在AngularJS中,有时需要在表单内包含某些控件,但又不希望这些控件导致表单变为脏状态。例如,当用户对表单进行修改后,表单的$dirty属性将变为true,触发保存对话框。然而,对于一些导航或辅助功能控件,我们可能并不希望它们触发这种行为。 ... [详细]
  • HDU 2537 键盘输入处理
    题目描述了一个名叫Pirates的男孩想要开发一款键盘输入软件,遇到了大小写字母判断的问题。本文提供了该问题的解决方案及实现方法。 ... [详细]
  • 笔记说明重学前端是程劭非(winter)【前手机淘宝前端负责人】在极客时间开的一个专栏,每天10分钟,重构你的前端知识体系& ... [详细]
author-avatar
G2602914553
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有