TP5 order排序

order方法属于模型的连贯操作方法之一,用于对操作的结果排序。

->order('sort desc,id desc')

 

用法如下:

Db::table('think_user')->where('status=1')->order('id desc')->limit(5)->select();

注意:连贯操作方法没有顺序,可以在select方法调用之前随便改变调用顺序。

支持对多个字段的排序,例如:

Db::table('think_user')->where('status=1')->order('id desc,status')->limit(5)->select();

如果没有指定desc或者asc排序规则的话,默认为asc。

如果你的字段和mysql关键字有冲突,那么建议采用数组方式调用,例如:

Db::table('think_user')->where('status=1')->order(['order','id'=>'desc'])->limit(5)->select(); 
tp5.1中的order FIELD可以通过使用orderRaw函数来实现。在orderRaw函数中,可以传入带有FIELD函数的排序字段,并且可以使用asc或desc来指定排序的方式。例如,可以这样写代码来实现按照u_id=0排序,然后按照sort排序的功能: ``` $or_str = "FIELD(u_id,0) desc,sort asc"; $p = db('product')->field('id,u_id,name,cover_img,sort,count') ->where('product_id', $ppi) ->orderRaw($or_str) ->paginate($limit)->jsonSerialize(); ``` 注意,order函数已经不再适用,应该使用orderRaw函数来构建排序语句。orderRaw函数可以解析mysql函数FIELD,并且可以通过传入bind参数来绑定参数。如果需要查看构建的SQL语句而不进行查询,可以使用fetchSql方法,并将其设置为true。例如: ``` $subQuery = Db::table('think_user') ->field('id,name') ->where('id', '>', 10) ->fetchSql(true) ->select(); ``` 这样可以得到构建的SQL语句而不进行实际的查询操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [TP5,TP6数据排序方法按指定函数FIELD排序的方法](https://blog.csdn.net/weixin_42433970/article/details/122556042)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [tp5.1--数据库子查询](https://blog.csdn.net/qq_42176520/article/details/88695871)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值