前言:
以下是MySQL最基本的增删改查语句,很多IT工作者都必须要会的命令,也 是IT行业面试最常考的知识点,由于是入门级基础命令,所有所有操作都建立在单表 上,未涉及多表操作。
4、“查”——之单表查询
MySQL从数据表中查询数据最基本的语句是SELECT语句,在前面的“增删查”已经 使用过:SELECT * FROM 表名,也就是查询指定数据表中的所有数据。下面将对 SELECT语句进行详细介绍。
在进行后面的操作之前我们先建立一个新的数据表student2,如下:
CREATE TABLE student2
(id INT(3) PRIMARY KEY AUTO_INCREMENT,name VARCHAR(20) NOT NULL,grade FLOAT,gender CHAR(2)
);
此处的PRIMARY KEY表示将该字段设为主键,AUTO_INCREMENT表示将该字段设 为开始值是 1,每条新记录自动递增 1,,所以在插入数据时不需为该字段设值;NOT NULL表示将该字段限制为非空值(此处不作详细讲解)
再向student2表中插入如下数据:
INSERT INTO student2(name,grade,gender)VALUES ('songjiang',40,'男'),('wuyong',100,'男'),
('qinming',90,'男'),('husanniang',88,'女'),('sunerniang',66,'女'),
('wusong',86,'男'),('linchong',92,'男'),('yanqing',90,NULL);
注意:
若因为此处插入的数据包含了中文而导致无法插入,可将“男/女”改为“man/woman”,或 者将字段编码改为utf8(方法自行百度,此处不做讲解)。
4.1 简单查询
4.1.1 查询所有字段
语法:SELECT 字段名1,字段名2,…FROM 表名
举例:查询student2表中的所有记录
命令:SELECT id,name,grade ,genderFROM student2;
结果:
注意:
字段顺序可以更改,如:
SELECT id,grade,gender ,nameFROM student2;
则显示的结果也会作出对应的调整:
4.1.2 在SELECT语句中使用(‘ * ’)通配符代替所有字段
语法:SELECT * FROM 表名;
在此前已多次使用此命令,所以此处不作赘述。
4.1.3 查询指定的部分字段
语法:SELECT 字段名1,字段名2,… FROM 表名;
举例:查询student2表中的name字段和gender字段
命令:SELECT name,gender FROM student2;
结果:
从结果中可以看到只显示了name和gender两个字段。
4.2 按条件查询
4.2.1 带关系运算符的查询
语法:SELECT 字段名1,字段名2,…
FROM 表名
WHERE 条件表达式
在WHERE子句中可以使用如下关系运算符:
举例:查询student2表中id为4的人的id和name字段
命令:SELECT id,name FROM student2 WHERE id=4;
结果:
举例:查询student2表中grade大于80的人的name和grade字段
命令:SELECT name FROM student2 WHERE grade>80;
结果:
4.2.2 带 IN 关键字的查询
IN关键字用于判断某个字段的值是否在指定集合中,若在,则该字段所在的记录将会被查询出来.
IN关键字用于判断某个字段的值是否在指定集合中,若在,则该字段所在的记录将会被查询出来.
语法:SELECT * | 字段名1,字段名2,…FROM 表名WHERE 字段名 [ NOT ] IN (元素1,元素2,…)
举例:查询student2表中id值为1,2,3的记录
命令:SELECT * FROM student2 WHERE id IN (1,2,3);
结果:
注意:
NOT IN 与 IN 相反,查询的是不在指定范围内的记录。
4.2.3 带 BETWEEN AND 关键字的查询
BETWEEN AND 用于判断某个字段的值是否在指定范围之内,若在,则该字段所在的记录会被查 询出来,反之不会。
语法:SELECT * | { 字段名1,字段名2,… }FROM 表名WHERE 字段名 [ NOT ] BETWEEN 值1 AND 值2;
举例:查询student2表中id值在2~5之间的人的id和name
命令:SELECT id,name FROM students WHERE id BETWEEN 2 AND 5;
结果:
注意:
NOT BETWEEN AND 表示查询指定范围外的记录。
4.2.4 空值查询
在数据表中有些值可能为空值(NULL),空值不同于0,也不同于空字符串,需要使用 IS NULL 来判断字段的值是否为空值。
语法:SELECT * | 字段名1,字段名2,…FROM 表名WHERE 字段名 IS [ NOT ] NULL
举例:查询student2表中gender值为空值的记录。
命令:SELECT * FROM student2 WHERE gender IS NULL;
结果:
注意:
IS NOT NULL 关键字用来查询字段不为空值的记录。
4.2.5 带 DISTINCT 关键字的查询
很多表中某些字段的数据存在重复的值,可以使用DISTINCT关键字来过滤重复的值,只保留一个 值。
语法:SELECT DISTINCT 字段名 FROM 表名;
举例:查询student2表中gender字段的值,结果中不允许出行重复的值。
命令:SELECT DISTINCT gender FROM student2;
结果:
注意:
DISTINCT 关键字还可作用于多个字段,则只有多个字段的值都完全相同时才会被认作是 重复记录。
4.2.6 带 LIKE 关键字的查询
语法:SELECT * | 字段名1,字段名2,…FROM 表名WHERE 字段名 [ NOT ] LIKE ‘匹配字符串’;
(1)百分号(%)通配符
匹配任意长度的字符串,包括空字符串。例如,字符串“ c% ”匹配以字符 c 开始,任意长度的字 符串,如“ ct ”,“ cut ”,“ current ”等;字符串“ c%g ”表示以字符 c 开始,以 g 结尾的字符 串;字符串“ %y% ”表示包含字符“ y ”的字符串,无论“ y ”在字符串的什么位置。 举例1:查询student2表中name字段以字符“ s ”开头的人的id,name
命令:SELECT id,name FROM student2 WHERE name LIKE "S%";
结果:
举例2:查询student2表中name字段以字符“ w ”开始,以字符“ g ”结尾的人的id,name。
命令:SELECT id,name FROM student2 WHERE name LIKE 'w%g';
结果:
举例3:查询student2表中name字段不包含“ y ”的人的id,name。
命令:SELECT id,name FROM student2 WHERE name NOT LIKE '%y%';
结果:
(2)下划线(_)通配符
下划线通配符只匹配单个字符,若要匹配多个字符,需要使用多个下划线通配符。例如,字符串“ cu_ ”匹配以字符串“ cu ”开始,长度为3的字符,如“ cut ”,“ cup ”;字符串“ c__l”匹配在“ c ”和“ l ”之间包含两个字符的字符串,如“ cool ”。需要注意的是,连续的“_”之间不能有空格,例 如“M_ _QL”只能匹配“My SQL”,不能匹配“MySQL”。
举例:查询在student2表中name字段值以“ wu ”开始,以“ ong ”结束,并且中间只有一个字符的记录。
命令:SELECT * FROM student2 WHERE name LIKE 'wu_ong';
结果:
注意:
若要查询的字段值本来就含有“ % ”或者“ _ ”,则要用“ \ ”进行转义,如要查询本身含有“ % ”的字符串,命令应改为 “ %\%%”。
4.2.7 带 AND 关键字的多条件查询
在使用SELECT语句查询数据时,优势为了使查询结果更加精确,可以使用多个查询条件,如使用 AND 关键字可以连接两个或多个查询条件。
语法:SELECT * | 字段名1,字段名2,…FROM 表名WHERE 条件表达式1 AND 条件表达式2 [ … AND 条件表达式 n ];
举例:查询student2表中 id 字段小于5,并且 gender 字段值为“ 女 ”的人的id和name
命令:SELECT id,name FROM student2 WHERE id<5 AND gender='女';
结果:
4.2.8 带 OR 关键字的多条件查询
与 AND 关键字不同,OR 关键字只要满足任意一个条件就会被查询出来
语法:SELECT * | 字段名1,字段名2,…FROM 表名WHERE 条件表达式1 OR 条件表达式2 [ … OR 条件表达式 n ];
举例:查询student2表中 id 字段小于3,或者 gender 字段值为“ 女 ”的人的id,name和gender
命令:SELECT id,name ,gender FROM student2 WHERE id<3 OR gender='女';
结果:
4.2.9 OR 和 AND 一起使用的情况
OR 和 AND 一起使用的时候,AND 的优先级高于 OR,因此二者一起使用时,会先运算 AND 两 边的表达式,再运算 OR 两边的表达式。
举例:查询student2表中gender值为“女”或者gender值为“男”并且grade字段值为100的人的记录
命令:SELECT * FROM student2 WHERE gender='女' OR gender='男' AND grade=100;
结果: