微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

thinkphp中if使用以及concat的使用实例

thinkPHP中联合if和concat的使用方法
"IF (pp.reason_name != '',concat( pp.reason_name, if(pp.remark != '',',',''), pp.remark  ),'' ) " => 'remark'
 if使用方法  IF(expr1,expr2,expr3)
如果 expr1 是TRUE (expr1 <> 0 and expr1 <> NULL),则 IF()的返回值为expr2; 否则返回值则为 expr3。IF()的返回值为数字值或字符串值,具体情况视其所在语境而定。
"IF (pp.reason_name != '','显示表达式' ,'')" => '使用别名'

concat使用方法
CONCAT()函数用于将多个字符串连接成一个字符串
例子

MysqL> SELECT CONCAT(’My’, ‘S’, ‘QL’);

-> ‘MysqL

concat( pp.reason_name, if(pp.remark != '',',',''), pp.remark  )
查询sql语句
Db::name('spu_info')->alias('pi')
            ->leftJoin('spu p', 'p.spu = pi.spu')
            ->leftJoin('sku k', 'k.spu = pi.spu')
            ->leftJoin('supplier s', 's.id = k.supplier_id')
            ->leftJoin('product_process pp', 'pp.id = p.process_id and pp.spu = p.spu')
            ->LeftJoin('spu_sub ss', 'ss.spu = pi.spu')
->field([ "IF (pp.reason_name != '',concat( pp.reason_name, if(pp.remark != '',',',''), pp.remark ),'' ) " => 'remark', 'pi.count', 'pi.is_copy'])->group('pi.spu') ->paginate( $pagesize, false, ['query' => Request::param()] )->toArray();

连接if 与concat使用实例

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐