前言
这里介绍数据库操作最重要的DQL查询操作
一、DQL语句
1.1 简要概述
数据库执行DQL语句不会对数据进行改变,而是让数据库发送结果集给客户端。查询返回的结果集是一张虚拟表。
查询关键字:SELECT
语法: SELECT 列名 FROM表名 【WHERE --> BROUP BY -->HAVING--> ORDER BY】
语法:
SELECT selection_list /*要查询的列名称*/
FROM table_list /*要查询的表名称*/
WHERE condition /*行条件*/
GROUP BY grouping_columns /*对结果分组*/
HAVING condition /*分组后的行条件*/
ORDER BY sorting_columns /*对结果分组*/
LIMIT offset_start, row_count /*结果限定*/
1.2 操作的数据信息
1.3 基础查询
#查询所有列
SELECT * FROM stu;
#查询指定列
SELECT sid, sname, age FROM stu;
1.4 条件查询
#条件查询就是在查询时给出WHERE子句,在WHERE子句中可以使用如下运算符及关键字:
=、!=、<>、<、<=、>、>=;
BETWEEN…AND;
IN(set);
IS NULL;
AND;
OR;
NOT;
#查询性别为女,并且年龄50的记录
SELECT * FROM stu WHERE gender='female' AND ge<50;
#查询学号为S_1001,或者姓名为liSi的记录
SELECT * FROM stu WHERE sid ='S_1001' OR sname='liSi';
#查询学号为S_1001,S_1002,S_1003的记录
SELECT * FROM stu WHERE sid IN ('S_1001','S_1002','S_1003');
#查询学号不是S_1001,S_1002,S_1003的记录
SELECT * FROM tab_student WHERE s_number NOT IN ('S_1001','S_1002','S_1003');
#查询年龄为null的记录
SELECT * FROM stu WHERE age IS NULL;
#查询年龄在20到40之间的学生记录
SELECT * FROM stu WHERE age>=20 AND age<=40;
或者
SELECT * FROM stu WHERE age BETWEEN 20 AND 40;
#查询性别非男的学生记录
SELECT * FROM stu WHERE gender!='male';
或者
SELECT * FROM stu WHERE gender<>'male';
或者
SELECT * FROM stu WHERE NOT gender='male';
#查询姓名不为null的学生记录
SELECT * FROM stu WHERE NOT sname IS NULL;
或者
SELECT * FROM stu WHERE sname IS NOT NULL;
1.5 模糊查询
#当想查询姓名中包含a字母的学生时就需要使用模糊查询了。模糊查询需要使用关键字LIKE。
通配符: '_' 任意一个字母
'%' 任意0~n个字母
#查询姓名由5个字母构成的学生记录
SELECT * FROM stu WHERE sname LIKE '_____';
#模糊查询必须使用LIKE关键字。其中 “_”匹配任意一个字母,5个“_”表示5个任意字母。
#查询姓名由5个字母构成,并且第5个字母为“i”的学生记录
SELECT * FROM stu WHERE sname LIKE '____i';
#查询姓名以“z”开头的学生记录
SELECT * FROM stu WHERE sname LIKE 'z%';
#其中“%”匹配0~n个任何字母。
#查询姓名中第2个字母为“i”的学生记录
SELECT * FROM stu WHERE sname LIKE '_i%';
#查询姓名中包含“a”字母的学生记录
SELECT * FROM stu WHERE sname LIKE '%a%';
1.6 字段控制查询
#去除重复记录
#去除重复记录(两行或两行以上记录中系列的上的数据都相同),例如emp表中sal字段就存在相同的记录。
#当只查询emp表的sal字段时,那么会出现重复记录,那么想去除重复记录,需要使用DISTINCT:
SELECT DISTINCT sal FROM emp;
#查看雇员的月薪与佣金之和
#因为sal和comm两列的类型都是数值类型,所以可以做加运算。
#如果sal或comm中有一个字段不是数值类型,那么会出错。
SELECT *,sal+comm FROM emp;
#comm列有很多记录的值为NULL,因为任何东西与NULL相加结果还是NULL,所以结算结果可能会出现NULL。
#下面使用了把NULL转换成数值0的函数IFNULL:
SELECT *,sal+IFNULL(comm,0) FROM emp;
#给列名添加别名
#在上面查询中出现列名为sal+IFNULL(comm,0),这很不美观,现在我们给这一列给出一个别名,为total:
SELECT *, sal+IFNULL(comm,0) AS total FROM emp;
#给列起别名时,是可以省略AS关键字的:
SELECT *,sal+IFNULL(comm,0) total FROM emp;