thinkphp6.0自定义排序order by field
2022-11-24 11:10:29
197
{{single.collect_count}}

相信很多时候我们需要有个自定义排序的功能,比如登录用户的点赞排序到第一位等等。

![](https://cdn.micuer.com/data/upload/avatar/20210128/1b7ad4e34aeb62eee4442099261c33c2.jpg)

这种情况下我们一般都是使用自定义排序的功能,那么原生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/

相信以上资料可以帮助到大家。

回帖
全部回帖({{commentCount}})
{{item.user.nickname}} {{item.user.group_title}} {{item.friend_time}}
{{item.content}}
{{item.comment_content_show ? '取消' : '回复'}} 删除
回帖
{{reply.user.nickname}} {{reply.user.group_title}} {{reply.friend_time}}
{{reply.content}}
{{reply.comment_content_show ? '取消' : '回复'}} 删除
回帖
收起
没有更多啦~
{{commentLoading ? '加载中...' : '查看更多评论'}}