tp5.1 order FIELD
时间: 2023-10-10 18:15:06 浏览: 147
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 ]
阅读全文