00 03数据库及SQL/MySQL基础之DQL

文章目录

  • 1 DQL(数据查询语言)之基础查询
  • 2 DQL(数据查)之条件查询
  • 3 DQL(数据查询语言)之模糊查询
  • 4 DQL(数据查询语言)之排序
  • 5 DQL(数据查询语言)之聚合查询
  • 6 DQL(数据查询语言)之分组查询
  • 7 DQL(数据查询语言)之limit子句

1 DQL(数据查询语言)之基础查询

1、字段(列)控制
(1)查询所有列
SELECT * FROM table_name;,其中*表示查询所有列。
(2)查询指定列
SELECT column1 [, column2, column3, ..., columnn] FROM table_name;
(3)完全重复的记录只有一次
当查询结果中的多行记录一摸一样时,只显示一行。一般查询所有列时很少会有这种情况,但只查询一列(或几列)时,可能性增大。
SELECT DISTINCT * | column1 [, column2, column3, ..., columnn] FROM table_name
(4)列运算
|——数值类型的的列可以做加、减、乘、除运算,SELECT num+1 FROM table_name;,无法转换将属性作为0看待。
|——字符串类型可以做连接运算,SELECT CONCAT('$', money) FROM table_name;
|——转换NULL值
|————有时需要把NULL转换成其它值,例如com+1000时,如果com列存在NULL值,那么NULL+1000的值也为NULL,而我们这时希望将NULL作为0来进行运算。
|————SELECT IFNULL(com, 0)+1000 FROM table_name;
|————IFNULL(com, 0);如果com中存在NULL值,那么当成0来运算。
|——给列起别名
|————SELECT IFNULL(com, 0)+1000 AS alias FROM table_name;,其中AS可以省略。

2 DQL(数据查)之条件查询

1、语法:SELECT * | column1 [, column2, column3, ..., columnn] FROM table_name [WHERE condition]
具体见这里有链接中的DML。

3 DQL(数据查询语言)之模糊查询

1、语法:SELECT * | column1 [, column2, column3, ..., columnn FROM table_name [WHERE column_name LIKE 'content'];
2、其中content中可以跟内容加匹配通配符%或者_,其中%代表0-N个字符,_代表一个字符。

4 DQL(数据查询语言)之排序

1、升序
(1)语法:SELECT * FROM table_name ORDER BY column_name ASC;
(2)ASC指升序排列,且可省略。
2、降序
(1)语法:SELECT * FROM table_name ORDER BY column_name DESC;
(2)DESC指降序排列,且不可省略。
3、使用多列作为排序条件
(1)语法:SELECT * FROM table_name ORDER BY column_name1 ASC, column_name2 DESC, ...;
(2)多个列属性进行排列,从第一个开始,一直到排序完成或至语句结束。

5 DQL(数据查询语言)之聚合查询

聚合函数用来做某列的纵向
1、COUNT
(1)语法:SELECT COUNT(* | column_name) FROM table_name
(2)用法:统计列属性中不为NULL的记录数。
2、MAX
(1)语法:SELECT MAX(column_name) FROM table_name
(2)用法:统计列属性中最大值。
3、MIN
(1)语法:SELECT MIN(column_name) FROM table_name
(2)用法:统计列属性中最小值。
4、SUM
(1)语法:SELECT SUM(column_name) FROM table_name
(2)用法:统计列属性中总值。
5、AVG
(1)语法:SELECT AVG(column_name) FROM table_name
(2)用法:统计列属性中平均值。

6 DQL(数据查询语言)之分组查询

1、语法:SELECT column_name FROM table_name GROUP BY column_name;
2、用法:用来分组的属性和显示的属性必须一样。
3、语法:SELECT column_name FROM table_name GROUP BY column_name HAVING condition;
3、用法:分组后筛选。

7 DQL(数据查询语言)之limit子句

1、LIMIT用来限定查询结果的起始行,以及总行数。
2、语法:SELECT * FROM table_name LIMIT startrow, count;
3、用法:常用于分页,从0开始计算行数。

你可能感兴趣的:(数据库开发)