12月2日:thinkphp中的链式操作
创始人
2024-03-12 01:46:52
0

补充内容:

今天我们就来聊聊limit和page的区别以及group by需要注意的点,where和having的区别

limit和page

区别

Limit

        限制查询数量,在进行分页查询的时候用的最多,但是limit在查询限制中的索引值是从0开始的,limit(0,10)代表从第1条数据开始,限制10条数据。

public function limitTest(){//limit//原生语句:select id,name from bro_demo limit(0,10) where status = 'normal';$result = Db::name('demo')->field('id,name')->where('status','=','normal')->limit(0,10)->select();dump($result);}

Page

        是thinkphp中自带的人性化分页查询,page方法不需要你自己计算每页的第一条数据,你只需要将每页页数和每页显示多少条数据交给他,他会自动帮你计算每页的第一条数据,例如:page(1,10)代表第一页显示10条数据。

public function pageTest(){//page//原生语句:select id,name from bro_demo page(1,10) where status = 'normal';$result = Db::name('demo')->field('id,name')->where('status','=','normal')->page(1,10)->select();dump($result);}

group by 分组

GROUP方法也是连贯操作方法之一,通常用于结合合计函数,根据一个或多个列对结果集进行分组 。group方法只有一个参数,并且只能使用字符串。

重点

//group by分组public function groupTest(){//原生语句:select id,name,max(score) from bro_score group(user_id);$result = Db::name('score')->field('id,name,max(score)')->group('user_id')->select();dump($result);}
group分两组,组中人员名称相同以最高分数为界限进行查询
group分两组,组中人员名称不同,选取最高分数后,查询出每组第一条数组赋值

having与where(重点)

区别

(1)where:

  • 是作用在查询结果进行分组之前,过滤掉不符合条件的数据。
  • where中不能包含聚合函数。(注意是:where后面子句不能有聚合函数,而在含有where中可以使用聚合函数)
  • 作用在group by和having字句前
  • 是作用于对表与视图

(2)having:

  • 是作用在查询结果分组之后,筛选满足条件的组,过滤掉数据。

  • 通常跟聚合函数一起使用。

  • having子句在聚合后对组记录进行筛选。

  • 是作用于分组

 //having和where的区别public function havingTest(){//where查询//原生语句: SELECT `id`,`name` FROM `bro_score` WHERE ( score>40 )$result = Db::name('score')->field('id,name')->where('score>40')->group('user_id')->select();dump($result);//having//原生语句:SELECT name,max(score) FROM `bro_score` GROUP BY `user_id` HAVING count(score)>=2$result = Db::name('score')->field('name,max(score)')->group('user_id')->having('count(score)>=2')->select();dump($result);}

执行顺序

当一个查询语句同时出现了where,group by,having,order by的时候,执行顺序和编写顺序是:

1.执行where()方法对全表数据做筛选,返回第1个结果集。

2.针对第1个结果集使用group by分组,返回第2个结果集。

3.针对第2个结果集中的每1组数据执行select()方法,有几组就执行几次,返回第3个结果集。

4.针对第3个结集执行having()方法进行筛选,返回第4个结果集。

5.针对第4个结果集使用order by排序。

相关内容

热门资讯

国家矿山安全监察局公布矿山智能... 人民财讯12月24日电,国家矿山安全监察局12月24日公布矿山智能化建设相关激励政策,其中提出,在煤...
中航基金杨中楷:政策+技术+资... 近日,A股商业航天板块在资本市场热度骤升。中航基金总监助理杨中楷在接受上海证券报记者专访时深入解读商...
北京:优化政策放宽非京籍家庭购... 新华社北京12月24日电(记者郭宇靖)为贯彻落实中央经济工作会议精神,着力稳定房地产市场,12月24...
清华招生办:遭冒用名义散布不实... 每经AI快讯,12月24日,清华大学招生办公室发布声明:近日,我办接到多所中学、家长及学生反映,有部...
北京楼市:三次松绑政策促需求释... 【12月24日消息,自去年9月起北京三次松绑楼市政策】自去年9月以来,北京已三次出台政策松绑楼市。业...
志邦家居(603801)发布董... 截至2025年12月24日收盘,志邦家居(603801)报收于9.22元,较前一交易日上涨0.44%...
注意,北京住房限购政策有调整! 24日,北京市住建委网站发布通知,进一步优化调整本市房地产相关政策,全文如下: 北京市住房和城乡建设...
鑫汇科及子公司陷施工合同纠纷 ... 12月24日,鑫汇科(920267)发布公告,公司及全资子公司鑫汇科电器的部分银行账户资金被冻结,冻...
北京房地产限购政策调整! | ... 12月24日,北京市住房城乡建设委、市发展改革委、人民银行北京市分行、北京住房公积金管理中心等4部门...