php中field函数,Thinkphp field() 数据库查询函数使用

TP 查询field小技巧

1. field 过滤掉某些字段

->where(['id'=>35])->field('delete_time',true)->find();复制代码

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

->field('title,email,content')->create();复制代码

3. field 操作新增字段

->field('id,name,price,0 as is_select')复制代码

4. field 运算 +-*/

->field('id,name,sales_origial_number+sales_actual_number as sales')复制代码

5. field 使用函数

->field('type,round(price) as price,time')复制代码

->field('type,count(id) as type_number')->group('type')->order('type_number')复制代码

->field(status,sum(price) as status_price)->group(status)->order(status_price)复制代码

6. field sum 统计次数

->field('count(id) as all_count,sum(star_rank = 1) as goods_review_count,sum(star_rank = 2) as middle_review_count,sum(star_rank = 3) as bad_review_count,sum(has_img = 2) as has_img_count')->where($where)->find();复制代码

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(substr(sn,1,2)='SY',1,0) as type")复制代码

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')复制代码

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值