MySQL 高级SQL语句

163 阅读2分钟

高级SQL语句(进阶查询)

准备一个表

image.png

order by

order by,按关键字排序。

注意:

  • 一般对数值字段进行排序。
  • 如果对字符类型的字段进行排序,则会按首字母排序。
 SELECT "字段" FROM "表名" [WHERE "条件"] ORDER BY "字段" [ASC|DESC] ;
 #ASC是按照升序进行排序的,是默认的排序方式。
 #DESC是按降序方式进行排序。

按分数排序,默认不指定是升序排列

image.png 分数按降序排列

image.png

order by还可以结合where进行条件过滤

image.png ORDER BY 语句也可以使用多个字段来进行排序,当排序的第一个字段相同的记录有多条的情况下,这些多条的记录再按照第二个字段进行排序,ORDER BY 后面跟多个字段时,字段之间使用英文逗号隔开,优先级是按先后顺序而定 但order by 之后的第一个参数只有在出现相同值时,第二个字段才有意义

image.png

查询学生信息先按兴趣id降序排列,相同分数的,id按升序排列

image.png

and 和 or

  • and:且。
  • or:或。
 SELECT "字段" FROM "表名" WHERE "条件1"  AND "条件2";
 SELECT "字段" FROM "表名" WHERE "条件1"  OR "条件2";

image.png

image.png

distinct

distinct,不显示重复的数据记录。

注意:关系型数据库,单次只能对一个字段去重。

 SELECT DISTINCT "字段" FROM "表名";

image.png

GROUP BY(用于分组和汇总)

对GROUPBY后面的字段的查询结果进行汇总分组,通常是结合聚合函数一起使用的

  • "GROUP BY"有一个原则,凡是在"GROUP BY"后面出现的字段,必须在SELECT 后面出现;
  • 凡是在SELECT 后面出现的、且未在聚合函数中出现的字段,必须出现在"GROUP BY"后面。

语法:

 SELECT 字段1,SUM(字段2) FROM 表名 GROUP BY 字段1;

image.png

结合where语句

image.png

限制结果条目

limit 限制输出的结果记录 在使用 MySQL SELECT 语句进行查询时,结果集返回的是所有匹配的记录(行)。有时候仅 需要返回第一行或者前几行,这时候就需要用到 LIMIT 子句

SELECT column1, column2, ... FROM table_name LIMIT [offset,] number

查询所有信息显示前4行记录

image.png

从第4行开始,往后显示3行内容

image.png

别名——字段别名、表別名

字段别名:

 SELECT 字段1,字段2 AS 字段2的别名 from 表名;   #AS可以省略不写

image.png