• (5)MySQL的查询:模糊查询(通配符查询like)、限制符查询(limit)、排序查询(order by)、分组查询(group by)、(子查询)


    注意事项

    指令语法的优先级: where > group by >order by > limit

    例:select count(id) as cnt,age from tablename where id > 6 group by age having cnt < 2 order by age desc limit 2,5

    PS:查找tablename表中age列从id列大于6后面开始分组,且计算age值相同的数量,然后查询相同数量小于2的数据以age降序排列,且从第二行开始取值一页显示5条

    通配符查询:like  #数据库查询肯定用索引,所以这个知识只要了解即可

    固定用法like + 条件

    1、% 代表所有字符(like ‘n%’ ) #查询只要以n开头的

    2、_  代表一个字符(like 'n_')   #查询只要字符串内有n都查询到

    where后面可以跟比较运算符和逻辑运算符(=、<、>、!=、not、or、and)

    PS:如果用like去搜索,就无法使用索引查询,索引查询的速度要快与通配符查询

    限制符查询:limit

    PS:应用在网页每页呈现多少数据

    select * from tablename limit 5; #tablename就是表名,数字5就是要取几行数据

    select * from tablename limit offset(4),5  #offset就是偏移量,意思就是从第几行开始,5就是要取几行

    限制符查询实例:page=1 的时候取10条数据

    思路:page=1的时候就取10条,就是从数据库中取10行(0-10),第二页就是要从数据库的10行开始取10条,以此类推

    page = 1 limit 0,10

    page = 2 limit 10,20

    page = 3 limit 20,10

    指令就是  page = n select * from tablename where 查询条件 limit (n-1)*10,10

    排序查询

    select * from tablename order by age;  #将列表中的数据通过age来进行升序排序,后面有asc和desc两个参数,如果不写,默认按照升序进行排序

    select * from tablename order by age asc;  #acs就是按照升序 排列

    select * from tablename order by age desc;  #desc就是按照降序排列

    select * from tablename order by age desc,id asc;  #优先按照age降序排列,如果age有相同的,就按照id进行升序排列 

    分组查询(用到分组查询必须要有一个聚合函数这是一定的配套的)

    PS:where 和having 的区别(都是用来过滤数据的),但是不同的where是过滤的原生的数据(没有经过处理的数据,比如分组等),having是过滤group by(分组)之后的数据进行二次筛选,这个程序设计者设计的,固定的

    PS:where是可以和having配合使用的,但是必须在group by 分组之前使用,即select count(id) as cut,age from tablename where id > 6 group by age having cnt < 2 #查找tablename中age列下序号6以后的值,并且分组默认升序排列,且计算相同的数量,查找相同数量<2的数据

    聚合函数:

    count()  #计数

    max()  #最大值

    min()  #最小值

    avg()  #去平均

    sum() #求和

    PS:sum和count是不同的,sum是做计算,count只是数个数

    语法:

    select 聚合函数 as name,条件1 from tablename group by 分组条件  #as name 是将聚合函数修改一个名字,能够更直观的在列表内呈现 group by 后面的就是以什么分组的条件 条件1就是列表内需要查询的列名

    PS:条件1肯定是和分组条件一样的,否则会出现数据查询不完全

    select count(id) as cnt,age from tablename group by age;   #分组age并且计算这个组相同的条件的数量   

    select count(id) as cnt,age from tablename  group by age having cnt < 2; #查询tablename表中age列然后计算相同age值的数量并且查找相同age数量<2的数据

    where和having连用

    select count(id) as cut,age from tablename where id > 6 group by age having cnt < 2 #查找tablename表中age列,且id列>6的值,并且分组,且计算相同的数量,查找相同数量<2的数据

    子查询(sql语句套sql语句) #不建议用,使用子查询后无法用索引,而且效率比连表查询还慢

    select * from tablename1 where 列名 in (select 列名 from tablename2); 

  • 相关阅读:
    10个实用的但偏执的Java编程技术
    分布式文件系统FastDFS设计原理
    👮 Golang Gin/Ace/Iris/Echo RBAC 鉴权库
    深入浅出爬虫之道: Python、Golang与GraphQuery的对比
    (.*?)
    开箱即用的高匿代理抓取工具
    6.可见性关键字(volidate)
    5.同步关键字(synchronized)
    4.等待和通知
    3.线程优先级
  • 原文地址:https://www.cnblogs.com/shizhengquan/p/10298815.html
Copyright © 2020-2023  润新知