数据查询与统计

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 数据查询与统计

<!--p.MsoNormal{         mso-style-name: 正文;         mso-style-parent: "";         margin: 0pt;         margin-bottom: .0001pt;         mso-pagination: none;         text-justify: inter-ideograph;         mso-font-kerning: 1.0000pt;     }             p.paragraph{         mso-style-noshow: yes;         margin-top: 5.0000pt;         margin-right: 0.0000pt;         margin-bottom: 5.0000pt;         margin-left: 0.0000pt;         mso-margin-top-alt: auto;         mso-margin-bottom-alt: auto;         text-align: left;         font-family: 等线;         mso-bidi-font-family: 'Times New Roman';         font-size: 12.0000pt;     }             @list l0:level1{                     mso-level-number-format:decimal;                     mso-level-text:"%1.";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l0:level2{                     mso-level-number-format:lower-alpha;                     mso-level-text:"%2)";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l0:level3{                     mso-level-number-format:lower-roman;                     mso-level-text:"%3.";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l0:level4{                     mso-level-number-format:decimal;                     mso-level-text:"%4.";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l0:level5{                     mso-level-number-format:lower-alpha;                     mso-level-text:"%5)";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l0:level6{                     mso-level-number-format:lower-roman;                     mso-level-text:"%6.";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l0:level7{                     mso-level-number-format:decimal;                     mso-level-text:"%7.";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l0:level8{                     mso-level-number-format:lower-alpha;                     mso-level-text:"%8)";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l0:level9{                     mso-level-number-format:lower-roman;                     mso-level-text:"%9.";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l1:level1{                     mso-level-number-format:decimal;                     mso-level-text:"(%1)";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l1:level2{                     mso-level-number-format:lower-alpha;                     mso-level-text:"%2)";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l1:level3{                     mso-level-number-format:lower-roman;                     mso-level-text:"%3.";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l1:level4{                     mso-level-number-format:decimal;                     mso-level-text:"%4.";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l1:level5{                     mso-level-number-format:lower-alpha;                     mso-level-text:"%5)";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l1:level6{                     mso-level-number-format:lower-roman;                     mso-level-text:"%6.";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l1:level7{                     mso-level-number-format:decimal;                     mso-level-text:"%7.";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l1:level8{                     mso-level-number-format:lower-alpha;                     mso-level-text:"%8)";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l1:level9{                     mso-level-number-format:lower-roman;                     mso-level-text:"%9.";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l2:level1{                     mso-level-number-format:decimal;                     mso-level-text:"(%1)";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l2:level2{                     mso-level-number-format:lower-alpha;                     mso-level-text:"%2)";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l2:level3{                     mso-level-number-format:lower-roman;                     mso-level-text:"%3.";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l2:level4{                     mso-level-number-format:decimal;                     mso-level-text:"%4.";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l2:level5{                     mso-level-number-format:lower-alpha;                     mso-level-text:"%5)";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l2:level6{                     mso-level-number-format:lower-roman;                     mso-level-text:"%6.";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l2:level7{                     mso-level-number-format:decimal;                     mso-level-text:"%7.";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l2:level8{                     mso-level-number-format:lower-alpha;                     mso-level-text:"%8)";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l2:level9{                     mso-level-number-format:lower-roman;                     mso-level-text:"%9.";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l3:level1{                     mso-level-number-format:decimal;                     mso-level-text:"(%1)";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l3:level2{                     mso-level-number-format:lower-alpha;                     mso-level-text:"%2)";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l3:level3{                     mso-level-number-format:lower-roman;                     mso-level-text:"%3.";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l3:level4{                     mso-level-number-format:decimal;                     mso-level-text:"%4.";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l3:level5{                     mso-level-number-format:lower-alpha;                     mso-level-text:"%5)";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l3:level6{                     mso-level-number-format:lower-roman;                     mso-level-text:"%6.";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l3:level7{                     mso-level-number-format:decimal;                     mso-level-text:"%7.";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l3:level8{                     mso-level-number-format:lower-alpha;                     mso-level-text:"%8)";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             @list l3:level9{                     mso-level-number-format:lower-roman;                     mso-level-text:"%9.";                     mso-level-number-position:left;                     font-family:Times New Roman;                     }             -->                                  

           1.    单表无条件查询

Select 列名,表达式,函数

From 表名

Order by 关键字 desc|asc

           (1)    查询指定列

select sno,sname,sage

   from student;

           (2)    查询所有列

mysql> select *

   -> from sc;

           (3)    表达式的使用

mysql> select sno,cno,grade * 0.6

   -> from sc;

           (4)    使用别名

mysql> select sno as 学号,cno as 课程号,grade * 0.6 as 期末成绩

   -> from sc;

           (5)    使用函数

select curdate() as 当前日期;

select year(curdate()) as 当前年份;

select month(curdate()) as 当前月份;

select day(curdate()) as 当前日;

思考:如何查询学生的出生年份?

mysql> select sno,sname,year(curdate())-sage as 出生年份

   -> from student;

           (6)    去掉重复

查找哪些同学选课了?

mysql> select distinct sno

   -> from sc;

           (7)    查找指定行的数据

mysql> select *

   -> from student limit 2,3;

           (8)    排序

mysql> select *

   -> from student

   -> order by sno desc|asc;

**默认是升序,降序desc

多关键字排序:

举例:查询学生选课信息,并按成绩降序排列,如果成绩相同,则按学号升序排列

mysql> select *

   -> from sc

   -> order by grade desc,sno;

           2.    带条件查询

(1)比较运算符 =  >  <    >=   <=   <> !=

查找成绩大于90分的记录

mysql> select *

   -> from sc

   -> where grade >= 90;

(2)区间运算符

x between a and b     a <= x <= b

x not between a and b     x > b 或 x<a

查找成绩在80—90之间的记录

mysql> select *

   -> from sc

   -> where grade between 80 and 90;

查找成绩在80—90之间的记录

mysql> select *

   -> from sc

   -> where grade not between 80 and 90;

(3)空值判断

查找成绩还没有录入的记录

mysql> select *

   -> from sc

   -> where grade is null;

查找成绩已经录入的记录

mysql> select *

   -> from sc

   -> where grade is not null;

(4)逻辑表达式

And   or   not

举例:查找18岁以上男同学信息

mysql> select *

   -> from student

    -> where sage > 18 and ssex = '男';

举例:查找18岁以上的或男同学信息

mysql> select *

   -> from student

-> where sage > 18 or ssex = '男';

(5)模糊查询    

关键字:like

通配符:% 代表任意多个任意字符

  _ 代表1个任意字符

举例:查找姓张的同学信息。

mysql> select *

   -> from student

   -> where sname like '张%';

举例:查找姓张的姓名为2个字的同学信息。

mysql> select *

   -> from student

   -> where sname like '张_';

举例:查找姓张的姓名为3个字的同学信息。

mysql> select *

   -> from student

   -> where sname like '张__';

举例:查找手机号以153开头,6结尾的同学信息

mysql> select *

   -> from student

   -> where tel like '153%6';

举例:查找手机号以153开头,倒数第2位是6的同学信息

mysql> select *

   -> from student

   -> where tel like '153%6_';

(6)列表运算符

就是or的简写

举例:查找18,20,21岁的同学信息

mysql> select *

   -> from student

   -> where sage = 18 or sage = 20 or sage = 21;

mysql> select *

   -> from student

   -> where sagein(18,20,21);

举例:查找选修了1号、2号、4号课程的学生学号。

           3.    统计与分组

Select

From

Where

Group by

Hving

Order by

           (1)    聚合函数

           (2)    分组 group by 关键字

举例:查找每门课的平均成绩

mysql> select cno,avg(grade)

   -> from sc

   -> group by cno;

练习:查找每个人的平均成绩

mysql> select sno,avg(grade)

   -> from sc

   -> group by sno;

练习:查询每个系男、女生人数

mysql> select dno,ssex,count(sno)

   -> from student

   -> group by dno,ssex;

           (3)    筛选having,永远跟着groupby

当条件中含有聚合函数时,用having

举例:查找平均成绩大于80分的课程

mysql> select cno,avg(grade)

   -> from sc

   -> group by cno

   -> having avg(grade) > 80;

练习:查询平均成绩在80分以上的学生学号和平均成绩

Select

From

Where

Group by

Hving

Order by

           4.    连接查询

(1)两表连接

from 表1join表2on表1.= 表2.

Select

From表1join表2on表1.= 表2.

Where

Group by

Hving

Order by

from student join sc onstudent.sno = sc.sno

举例:查找刘晨的各科成绩

Select成绩

From sc join student on student.sno = sc.sno

Where sname = 刘晨

练习:输出所有女生的学号、姓名、课程号及成绩

mysql> select student.sno,sname,cno,grade

   -> from student join sc on student.sno = sc.sno

   -> where ssex = '女';

查询选修数据库课程的学生学号及其成绩

mysql> select sno,grade

   -> from sc join course on sc.cno = course.cno

   -> where cname = '数据库';

查询计算机系有哪些同学

mysql> select sno,sname

   -> from student join dept on student.dno = dept.dno

   -> where dname = '计算机系';

(2)多表连接

Student---sc ---course

From student join sc on student.sno = sc.sno

Join course on sc.cno = course.cno

举例:查询选修了数据库课程的名单

学生名单(student)---sc --- 数据库课程(course)

select student.sno,sname

from student join sc on student.sno = sc.sno

            join course on sc.cno = course.cno

where cname = '数据库';

练习:查找李勇选修的课程名

select cname

from student join sc on student.sno = sc.sno

            join course on sc.cno = course.cno

where sname = '李勇';

4张表的举例:同学选修的课程名(不要求)

计算机系dept—dno---student—sno---sc—cno--course课程名

select cname

from student join sc on student.sno = sc.sno

            join course on sc.cno = course.cno

            join dept on student.dno = dept.dno

where dname = '计算机系';

(3)外连接

举例:查看所有同学的选课情况

mysql> select student.sno,sname,cno,grade

-> from student left join sc on student.sno = sc.sno;

**join左边表中不满足连接条件的记录也出现

练习:各门课的选修情况。

mysql> select sc.cno,course.cno,grade

   -> from sc right join course on sc.cno = course.cno;

           5.    子查询

理解什么是子查询

           (1)    子查询返回单个值

举例1:c01号课程中谁的成绩不低于平均成绩?

select sno

from sc

where cno = 'c01' and grade >= (select avg(grade)

                            from sc

                                where cno = 'c01');

举例2:查询和刘晨在同一个系的学生信息。

select *

from student

where sname <> '刘晨' and dno = (select dno

                               from student

                               where sname = '刘晨');

           (2)    子查询返回值列表:可以使用innot inanyall操作符

举例1查询选修c03课程的学生平均年龄。

select avg(sage)

from student

where sno in (select sno

           from sc

           where cno = 'c03');

关于any和all举例:

查询成绩高于3号课任何成绩的选课信息

select*

from sc

where grade >any(select grade

from sc

where sno ='0003');

查询成绩高于3号课所有成绩的选课信息

select*

from sc

where grade > all (select grade

from sc

where sno ='0003');

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
6月前
|
SQL 大数据
每天一道大厂SQL题【Day03】订单量统计
每天一道大厂SQL题【Day03】订单量统计
74 0
|
1月前
|
SQL 算法 关系型数据库
浅析MySQL优化器统计信息
本文基于MySQL 8.0.34版本的源代码,详细介绍了MySQL中统计信息的计算和更新机制。文章首先概述了`records_per_key`统计信息在代价估计和Join Reorder算法中的重要性,接着了InnoDB统计信息的存储和计算方法,包括表级和索引级的统计信息。文章还介绍了统计信息的采样算法,特别是重要性采样在减少估计方差中的应用。此外,文章讨论了统计信息的更新时机,包括手动更新和自动更新。最后,文章简要介绍了直方图和其它统计信息,如表在内存中的占比估计,并通过实例展示了如何使用optimizer trace来分析查询优化过程。希望本文能帮助读者更好地理解MySQL的优化器。
|
5月前
|
NoSQL MongoDB 数据库
查询数据
查询数据
41 4
如何查询当前年最新的数据以及这条数据的上一年的最新数据?
如何查询当前年最新的数据以及这条数据的上一年的最新数据
64 0
|
6月前
|
关系型数据库 MySQL 数据库
『 MySQL数据库 』聚合统计
『 MySQL数据库 』聚合统计
|
BI 索引
|
SQL Oracle 关系型数据库
mysql查询时间段内的数据
mysql查询时间段内的数据
193 0
|
SQL 关系型数据库 MySQL
基础DQL(数据查询)——排序查询和分页查询
基础DQL(数据查询)——排序查询和分页查询
156 0
基础DQL(数据查询)——排序查询和分页查询
|
6月前
|
算法 Oracle 关系型数据库
数据库等值查询与统计信息
简介: 统计信息是为优化器的 cost 估算提供数据支撑,其中很重要的一点需求便是等值查询(EQUALS, IN 等) 场景下的基数估算。
110 0
数据库等值查询与统计信息
|
SQL 监控 HIVE
网站流量日志分析--统计分析--多维统计分析--时间维度--维表关联查询|学习笔记
快速学习网站流量日志分析--统计分析--多维统计分析--时间维度--维表关联查询
239 0
网站流量日志分析--统计分析--多维统计分析--时间维度--维表关联查询|学习笔记
下一篇
无影云桌面