(一)使用select语句,用order by来进行排序
1、select id,name from info order by 列名;
2、ASC:升序排序,默认就是升序,可以不加
(1)select id,name from info order by id;
data:image/s3,"s3://crabby-images/e8710/e87106306cf7fe8df2d97ffa3c1c894a7dcb31ae" alt=""
3、desc:降序排序,需要添加
(1)select id,name from info order by id desc;
data:image/s3,"s3://crabby-images/551a7/551a7f83fde935eb1fb51f45a52f016ef019032e" alt=""
4、使用order by,结合where条件进行过滤
(1)select name,score from info where address='南京西路' ORDER BY score desc;
(2)select id,name,score from info where sex='女' ORDER BY id desc,score desc;
(只有第一个参数出现相同值时,也就是出现重复值时,第二个才会按照要求排序)
(二)区间判断查询和去重查询
1、and:且
select * from info where score > 80 and score <=90;
data:image/s3,"s3://crabby-images/39a01/39a0158e421c959f3c6f5e2ab0e25d5c3aaa9c06" alt=""
2、or:或
select * from info where score > 80 or score < 90;
data:image/s3,"s3://crabby-images/750d8/750d82cbb59833f28e9c5956b34c5823986fb412" alt=""
3、嵌套条件:
(1)select * from info where score > 70 and ( score > 75 and score < 90 );
data:image/s3,"s3://crabby-images/25b29/25b29398147593fe7980bc48c9432d950a46a92b" alt=""
(2)select * from info where sex='男' and ( score > 80 and score < 90);
data:image/s3,"s3://crabby-images/e4720/e4720ebd0aaf60fd216a33c996536c1eb7e7c9d5" alt=""
4、去重查询(重点)
(1)select distinct sex from info;
data:image/s3,"s3://crabby-images/937b9/937b9fbce63381cd73b2f513f0bede34df1abcbf" alt=""
(2)select DISTINCT address from info where score = 90 and sex='男' ;
(三)分组查询:group by语句(一般结合聚合函数使用)
1、聚合函数(使用聚合函数,必须要加group by)
(1)count():统计有多少行
(2)sum():列的值相加,求和
(3)avg():列的值求平均数
(4)max():过滤出列的最大值
(5)min():过滤出列的最小值
2、分组
(1)分组的时候可以按照一个字段,也可以按照多个字段对结果进行分组
(2)分组的条件,要选用有多个重复值的列,过滤条件要用having语句过滤
3、格式:select count(name),sex from info GROUP BY sex;
4、统计行数count()
(1)select count(name),sex from info GROUP BY sex;
data:image/s3,"s3://crabby-images/19911/19911ef06d61a4e84da335477f313db44a5c3ded" alt=""
(2)根据where条件筛选,score>80
select count(name),sex,score from info where score >= 80 GROUP BY sex;
data:image/s3,"s3://crabby-images/f45dd/f45dd7e87f589de999fad8949a9d7160d9d14735" alt=""
5、求和
(1)以地址为分组,对score求和
select sum(score),address from info group by address;
data:image/s3,"s3://crabby-images/fef86/fef865f664ae1f5c7c02d5c313f85482ee0a543a" alt=""
6、求平均值
(1)select avg(score),sex from info GROUP BY sex;
data:image/s3,"s3://crabby-images/213f0/213f04a0b00a38d81fda41fe6fb7c0217c0e2f93" alt=""
7、最小值
(1) select min(score),sex,name from info GROUP BY sex;
data:image/s3,"s3://crabby-images/d805f/d805f55553e863aa5d58ce3f828f7bc9ad3ad9f3" alt=""
8、group by使用having语句实现条件过滤(having)
(1)select avg(score),address from info group by address having avg(score) > 60 ;
data:image/s3,"s3://crabby-images/1c1fe/1c1fe707bc97c7ab3f2355dfbb60879da5873140" alt=""
(2)按照地址分组,求成绩的平均值,然后>50,按照id的降序排序
select avg(score),address,id from info GROUP BY address having avg(score) > 50 order by id desc;
data:image/s3,"s3://crabby-images/14d52/14d527b8f172531e97965870f7427efe679ea1dc" alt=""
(3)统计name的行数,然后计算出学生的个数,然后把成绩也查出来,然后按照统计出来的学生个数,升序排列,按照地址分组,学生的成绩>=70
select count(name),score,address from info GROUP BY address having score >= 70 ORDER BY count(name) ;
data:image/s3,"s3://crabby-images/0d8e1/0d8e18e166024f8fefbe29f8a57859c3bf000e9d" alt=""
(4)按照性别分组,求出男生和女生的最大成绩,最大成绩是否超过75分,满足条件的过滤出来
select max(score),sex from info GROUP BY sex having max(score) > 75 ;
data:image/s3,"s3://crabby-images/4244f/4244fd6c3f557760583627b2d79299b59749b835" alt=""
(四)limit(限制输出的结果记录,查看表中的指定行)
1、格式:select * from info limit 3
2、select * from info limit 5,3;
data:image/s3,"s3://crabby-images/94a4c/94a4c33ecfff67fc17e860c78823fc105b989cbb" alt=""
3、快速查看后几行
(1)select * from info order by id desc limit 3;
data:image/s3,"s3://crabby-images/d73a4/d73a4f0e87f7a46310fec100d9587e1fb4e2c01f" alt=""
(五)通配符
1、通配符
(1)通配符:主要用于替换字符串中的部分字符,通过部分字符的匹配将相关的结果查询出来
(2)通配符和like一起使用,使用where语句一起完成查询
(3)通配符可以结合在一起使用
2、通配符的种类
(1)%:表示0个、1个、或者多个
(2)_:表示单个字符
3、格式
(1)以什么为开头:select * from info where address like ' 南% ';
data:image/s3,"s3://crabby-images/76aaa/76aaa86126de64718251a36be650cef6f6676a53" alt=""
(2)以什么为结尾:select * from info where address like ' %西 ';
data:image/s3,"s3://crabby-images/d13c0/d13c0c903c2d35b31551399140d82caadaa2f376" alt=""
(3)表示内容当中包含:select * from info where address like ' %西路% ';
data:image/s3,"s3://crabby-images/92f9c/92f9c3d69e5b4df12eddd8d3a4a84c01a67dd519" alt=""
(4)表示单个字符:select * from info where name like ' 小_A ';
data:image/s3,"s3://crabby-images/0e8e7/0e8e71ce0a41de1a9da189a10d2c8c8ca76495bf" alt=""
(5)结合使用:select * from info where address like ' 山%__ ';
data:image/s3,"s3://crabby-images/439d1/439d1751085226e3464a46deaa872cdfc823a980" alt=""
(六)别名
1、设置别名:alias (as)
(1)在mysql查询时,表的名字或者字段名太长,可以使用别名进行替代,方便书写
(2)可以给表起别名,但是要注意别名不能和数据库中其他的表名冲突
(3)列的别名在结果中可以显示,但是表的别名在结果中没有显示,只能用于查询
2、格式
(1)select name as 姓名,score as成绩 from info;
data:image/s3,"s3://crabby-images/e1a47/e1a475f73bca1e4cf0e0161ec35a6ca7db1c9c9a" alt=""
( 2 ) select name 姓名,score 成绩 from info;
data:image/s3,"s3://crabby-images/e1a47/e1a475f73bca1e4cf0e0161ec35a6ca7db1c9c9a" alt=""
(3)给表设置别名:select name 姓名,score 成绩 from info a;
(4)select name 姓名,score 成绩 from info a where name ='小a' and id = a.id;
①id是info表的id
②a.id是info表(别名a)的id
(5)使用as复制表,约束不会被复制过来
①create table test1 as select * from info;
创建一个表test,test的数据结构从info复制过来,但是约束不会被复制
data:image/s3,"s3://crabby-images/272a7/272a73b8fe72b95ebfb91baa66217c36ecd736d0" alt=""
data:image/s3,"s3://crabby-images/ca521/ca521cdb0cc393da4e587a074877ab2e3a931efe" alt=""
②create table test2 as select * from info where score >= 60;
data:image/s3,"s3://crabby-images/272a7/272a73b8fe72b95ebfb91baa66217c36ecd736d0" alt=""
data:image/s3,"s3://crabby-images/bf3f5/bf3f52a4bba77eb59bb82caf8227ae4012ea15ea" alt=""