引言:
数据操纵语言(Data Manipulation Language, DML)是SQL语言中,负责对数据库对象运行数据访问工作的指令集,以INSERT、UPDATE、DELETE三种指令为核心,分别代表插入、更新与删除,是开发以数据为中心的应用程序必定会使用到的指令
实践操作
这篇是延续于上一篇更新写的,上一篇的文章:MYSQL学习系列--DML语句(一)
我们上一次分别说了插入、更新、删除记录,这篇我们来介绍查询的不同玩法(涉及到一些常用函数)
4)查询记录select 字段 from 表名
1>查询不重复的记录
这里我们利用mysql自带的数据库来演示(information_schema)
首先我们需要use这数据库use information_schema;
之后查询select COLUMN_NAME from COLUMNS;
一般使用distinct,只筛选一个字段!这是在单表的时候select distinct COLUMN_NAME from COLUMNS;
记录还是很多,但是你会发现不会像之前那样重复的都还显示
2>条件查询
注:条件字段比较符号:
=,<,>,>=,<=,!=等比较运算符
多个条件之间可以使用or and等
where 后面接条件select * from 表名 where 条件
这个我就不演示了,需要你们自己发挥你们的想象力
3>排序和限制
语法:order by 字段名 排序方式
我们先将数据顺序打乱,然后进行排序
asc:由低到高,也是默认值
desc:由高到底
多个字段排序
限制:
在语句的最后面 加上limit 数字1,数字2 来进行查询数量的限制。
limit 数字1,数字2 数字1代表从第几条记录开启取(是从0开始的),数字2代表取几条!
4>聚合
①sum求和select sum(字段名) from 表名;
②count记录总数select count(*|字段名) from 表名;
③max最大值select max(字段名) from 表名;
④min最小值select min(字段名) from 表名;
⑤GROUP BY分类聚合select sum(number),Name from student group by Name;
⑥WITH ROLLUP分类聚合后的结果进行再汇总select sum(number) from student group by Name with rollup;
⑦HAVING
注意:having和where的区别在于,having是对聚合后的结果进行条件过滤,而where是在聚合前就对记录进行过滤 ,应该尽可能的对记录进行先过滤!
不明白的可以自己百度研究研究!!!或者给我留言