相信很多时候我们需要有个自定义排序的功能,比如登录用户的点赞排序到第一位等等。
这种情况下我们一般都是使用自定义排序的功能,那么原生sql又是怎么实现的呢?
SELECT * FROM `ct_xxx` ORDER BY field(id,2,1,3) //示例代码
SELECT * FROM `zhe_work_order` WHERE ( `uid` = 221 ) AND `zhe_work_order`.`delete_time` IS NULL ORDER BY field(id,1798) desc
那么在thinkphp6.0中我们如何封装成这样的语句?
1
$list = WorkOrder::where("uid",$user["id"])
->orderRaw("field(id,2,12,9")
->select();
//或者 2
$list = WorkOrder::where("uid",$user["id"])
->orderRaw("field(id,8")
->select();
//或者3
Db::table('think_user')
->where('status', 1)
->orderRaw("field(name,'thinkphp','onethink','kancloud')")
->limit(5)
->select();
//或者 4
$list = WorkOrder::where("uid",$user["id"])
->orderRaw("field(id,1587) desc")
->select();
以上的方法都是可以的。建议使用第四种情况
本篇文章仅针对thinkphp6.0及以上版本,thinkphp5.0 - 5.1 3.2 等版本参考
https://blog.csdn.net/Aaroun/article/details/86631013
https://blog.csdn.net/qq_39973053/article/details/82864659
https://www.pianshen.com/article/36621161922/
相信以上资料可以帮助到大家。