MySQL/MariaDB DML操作之Select

前言

上文我们已经讲解了MySQL/MariaDB的基础知识和DDL相关操作,接下来我们来说一下MySQL/MariaDB的DML操作,因select查询较复杂也较重要,所以本文主要是对select查询的详解。

DML操作

DML.jpg

DML之select

投影查询

select col_name,[col_name1,...] from table_name;

select * from table_name ;#显示全表
遍历整张数据表,但对系统资源消耗较大,再进行大数据量的查询时,禁止使用这类操作

条件查询

select col_name,[col_name1,...] from table_name where where_definition
#条件比较操作符
=    #等值比较
<=>  #等值比较,包括与NULL的安全比较
<>或!=  #不等值比较
<,<=,>,>=  #其它比较符
IN  #指定范围内值的存在性测试
BETWEEN … AND …  #在某取值范围内
IS NULL  #是否为空值
IS NOT NULL  #是否为非空
LIKE  #可使用通配符:%, _
RLIKE或REGEXP  #可使用正则表达式的模式
#逻辑操作符
AND 
OR
NOT

 聚合查询

AVG():平均值 
SUM():总和
MAX():最大值
MIN():最小值
COUNT():记录总数

子句修饰符

GROUP BY #对符合条件的结果进行分组
HAVING: 对聚合查询的结果做过滤
ORDER BY col1[,col2] {ASC|DESC} #排序
LIMIT [Offset,]count #限制输出行数

select执行流程

FROM --> WHERE --> GROUP BY --> HAVING --> ORDER BY --> SELECT --> LIMIT

连接查询

事先将两张或多张表执行相应的join操作,而后根据join结果做查询

CROSS JOIN:笛卡尔积,交叉连接
select * from tab1,tab2; 
INNER JOIN:内连接
#等值连接
select * from tab1 inner join tab2 on tab1.col_name = tab2.col_name
OUTER JOIN:外连接
LEFT OUTER JOIN:左外连接
select s.name as student,t.name as teacher from students as s lift join teachers as t 
on s.TeacherID = t.TID;  
RIGHT OUTER JOIN:右外连接    
select s.name as student,t.name as teacher from students as s right join teachers as t
on s.TeacherID = t.TID;    
NATURAL JOIN:自然连接,等值连接
select tab1.col_name,tab2.col_name from tab1,tab2 where tab1.col_name = tab2.col_name;

子查询

基于某查询语句的结果再次进行的查询

用于where子句的子查询

①用于比较表达式中的子查询
要求子查询只能返回单个结果				
select Name,Age from students where Age > (select AVG(Age) from students);
②用于in中的子查询
判断是否存在于指定的列表中
select Name from students where StuID in (select TID from teschers);
③用于exists中子查询

用于from中的子查询

select alias.col,... from (select statement) as alias where clause

select s.Name from (select * from students where Age > 20) as s where s.Name like 's%';

注:MySQL/MariaDB在子查询优化方面并不成熟,所以尽量避免使用子查询

联合查询

将两外或多个返回值字段相同的查询的结果合并输出

select statement union select statement

select Name,Age from teachers where Age>=40 union select Name,Age from students where Age>=40;

select实战

表结构

1.jpg

2.jpg

以ClassID分组,显示每班的同学的人数

3.jpg

以Gender分组,显示其年龄之和

4.jpg

以ClassID分组,显示其平均年龄大于25的班级

5.jpg

以Gender分组,显示各组中年龄大于25的学员的年龄之和

6.jpg

显示前5位同学的姓名、课程及成绩

7.jpg

显示其成绩高于80的同学的名称及课程

8.jpg

求前8位同学每位同学自己两门课的平均成绩,并按降序排列

9.jpg

显示每门课程课程名称及学习了这门课的同学的个数

10.jpg

显示其年龄大于平均年龄的同学的名字

11.jpg

统计各班级中年龄大于全校同学平均年龄的人数

12.jpg

The end

好了,select查询就先说到这里了,看起来select就这么点东西,其实要真正用好并不容易,所以小伙伴们多加练习吧,后续文章还会继续讲解MySQL/MariaDB系列的知识,有兴趣的可继续关注哦。以上仅为个人学习整理,如有错漏,大神勿喷~~~

原创文章,作者:书生,如若转载,请注明出处:http://www.178linux.com/4064

(0)
书生书生
上一篇 2015-05-07 09:30
下一篇 2015-05-07 09:41

相关推荐

  • 马哥教育网络班20期+第2周课程练习

    1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。  文件管理类命令有ls,cat,touch,stat,cp,mv,rm等  ls:查看文件,其使用方法以及常用选项有: Usage: ls [OPTION]… [FILE]… 常用选项:   -a:列出所有内容,包括.和.. &…

    Linux干货 2016-06-23
  • 系统管理之系统启动及内核编译

    CentOS 5和6的启动流程服务管理Grub管理自制Linux启动排错编译安装内核 系统启动流程:  POST –> 读取BootSequence (BIOS),决定引导次序 –>读取引导设备的Bootloader(MBR grubstage1–>stage1.5/boot…

    Linux干货 2016-09-13
  • N26-第六周作业

    vim编辑器的使用 编辑模式:默认模式编辑模式–>输入模式;i:insert,在光标所在处输入;a:append,在光标所在处后方输入o:在光标所在处下方打开的一个新行;光标处在行首;I:在光标所在行的行首输入A:在光标所在处的行尾输入;O:在光标所在处的上方打开一个新行; 输入模式–>编辑模式ESC 编辑模式&#8211…

    Linux干货 2017-03-13
  • 一周学会shell编程之小结1

    一周学会shell编程之小结1 内容: shell脚本创建与执行 变量 条件测试 if,case判断语句 练习   检查错误: bash -n path 调试执行: bash -x path   创建shell脚本步骤: 1 添加第一行 #!/bin/bash 2 给予…

    Linux干货 2016-08-15
  • 进程工具总结

    一、top命令         top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器。top是一个动态显示过程,即可以通过用户按键来不断刷新当前状态.如果在前台执行该命令,它将独占前台,直到用户终止该程序为止.比较准确的说,top命令提供了实时的对系统处…

    Linux干货 2016-09-12
  • DNS服务器搭建示例

    DNS服务器搭建示例 负责解析magedu.com域名,能够对一些主机名进行正向解析和逆向解析 配置主配置文件 [root@slave1 etc]# vim /etc/named.conf options { listen-on port 53 { 192.168.91.132; }; // listen-on-v6 port 53 { ::1; }; di…

    2017-09-16