TP6中Field使用

1. field 过滤掉某些字段

field('delete_time')->select();   //过滤delete_time字段

2. field 写入字段合法性检测

field('name')->create();  //仅新增name字段

3. field 操作新增字段

field('0 as selected');  //将0赋值给新增字段selected

4. field 运算 +-*/

->field('coupn+paper as card');  //优惠券数量(Number)+红包数量(Number)=card(卡包)

5. field 使用函数

->field('intval(price) as price');  //对价格字段Price取整格式化

->field('count(user_id) as user_count')->order('user_count');  //安装用户数据条数进行排序

->field(sum(price) as user_price)->order(user_price);  //安装用户金额汇总进行排序

6. field sum 统计次数

field('sum(status = 1) as user_sum');  //status=1数据求和

7. field case when 的使用

->field('count(id) as all_count,IFNULL(SUM(CASE WHEN has_img = 2 THEN 1 END),0) as has_img_count,IFNULL(SUM(CASE WHEN star_rank = 1 THEN 1 END),0) as goods_review_count,IFNULL(SUM(CASE WHEN star_rank = 2 THEN 1 END),0) as middle_review_count,IFNULL(SUM(CASE WHEN star_rank = 3 THEN 1 END),0) as bad_review_count')->where($where)->find();

8. field 里作判断

->field("if(price > $money,1,-1) as status");  //status = price > $money ? 1 : -1

9. field group 之后 某一个字段以“,”分割形式展示

->group(id)->field('group_concat(score order by `score ` desc) as score');

10. group 之后 field 里面查询最新一条里面的数据

->group('status')->field('SUBSTRING_INDEX(group_concat(id order by `id` desc),",",1) as id');

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
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
发出的红包

打赏作者

糯麦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值