mysql 字符串逗号搜索

5 篇文章 0 订阅

查找user表  str字段。

例如:要搜索的字符串是   1,2,3  【str字段只要包含任何一个就查出来】

最后的结果应该是   id为1,3,4 的三条数据

方法1:

$field = "u.*,d.id as s_id";
$res = $user->alias('u')
            ->field($field)
            ->leftJoin('datatree d',"FIND_IN_SET(d.id,u.str)")
            ->whereIn('d.id',$str)
            ->group('u.name')
            ->select();
sql:
SELECT `u`.*,d.id as s_id FROM `user` `u` LEFT JOIN `datatree` `d` ON FIND_IN_SET(d.id,u.str) WHERE  `d`.`id` IN ('1','2','3') GROUP BY `u`.`name`

方法2:

        $str = "1,2,3";    // 要搜索的值
        // 准备查找数据库只要包含上面的任何一个就查出来。
        $arr = explode(',', $str);
        $extra_where = function ($query) use ($arr) {
            foreach ($arr as $id) {
                $query->whereor(Db::raw("FIND_IN_SET({$id},str)"));
            }
        };
        $query = $user->where($extra_where)->buildSql();
        $res = $user->where($extra_where)->column('id');

sql:

SELECT * FROM `user` WHERE  (  ( FIND_IN_SET(1,str) )  OR ( FIND_IN_SET(2,str) )  OR ( FIND_IN_SET(3,str) ) )

最后的结果:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值