迅睿框架 版主:迅睿框架研发组
where语法拼接问题
类型:迅睿CMS 更新时间:2025-10-01 11:35:34

$where[] = 'keyword LIKE "%'.$data['keyword'].'%"';
$where[] = 'name LIKE "%'.$data['keyword'].'%"';
$where[] = '`'.$table.'`.`catids` LIKE "%\"'.intval($c).'\"%"';

在模型中使用->where($where)时,$where[0]会变成0默认不是数字,sql中体现为,出现拼接错误,如果使用where()这个有办法规避吗?

SELECT 
`id`, `keyword`, `keyword_id`
FROM `jm_keyword_rank` 
WHERE 
`search_engine` = 'baidu_pc' 
AND 
0 = 'keyword LIKE \"%ASE光源%\"' 
GROUP BY 
`keyword_id` 
ORDER BY 
`inputtime` DESC LIMIT 10

回帖
  • 迅睿官方技术专家
    #1楼    迅睿官方技术专家
    2025-10-01 08:35:15
    Chrome 0
    ->where(implode(" AND ", $where))
  • PHP学生
    #2楼    PHP学生
    2025-10-01 08:58:56
    iPhone手机 0

    目前就是这样处理的,这个是bug 吗?

    如果直接写sql 调用$this->query($sql),查不出数据,在sql中就可以查到数据,这个是啥原因的?

  • 迅睿官方技术专家
    #3楼    迅睿官方技术专家
    2025-10-01 10:33:34
    Chrome 0
    不是bug,where不能传入数组格式啊
  • PHP学生
    #4楼    PHP学生
    2025-10-01 10:48:20
    Chrome 0
    哦,但是第二个数组就没有问题了,就第一个有这样的问题。如果是多组where,不使用数组,是要自己拼接成一个吗?好像where()只做一些简单的赋值,复杂的就不行。比如:
    $where[] = '`top_rank` <= 10';
    
    $where[] = '`top_rank` <= 20';
    
    $where[] = '`top_rank` <= 30';
    
    $where[] = '`keyword` LIKE "%'.$data['keyword'].'%"';
    
    $where[] = '`search_engine` = "baidu_pc"';
  • 迅睿官方技术专家
    #5楼    迅睿官方技术专家
    2025-10-01 11:10:02
    Chrome 0
    $where[] = '`top_rank` <= 10';
    
    $where[] = '`top_rank` <= 20';
    
    $where[] = '`top_rank` <= 30';
    
    $where[] = '`keyword` LIKE "%'.$data['keyword'].'%"';
    
    $where[] = '`search_engine` = "baidu_pc"';
    ->where(implode(" AND ", $where)) 这样

    或者
    ->where('`top_rank` <= 10')->where('`top_rank` <= 20')->where('`top_rank` <= 30')
    满意答案
  • PHP学生
    #6楼    PHP学生
    2025-10-01 11:14:09
    Chrome 0
    迅睿官方技术专家 使用的是这种->where(implode(" AND ", $where)),还是要自己处理
    $where[] = '`top_rank` <= 10';
    
    $where[] = '`top_rank` <= 20';
    
    $where[] = '`top_rank` <= 30';
    这个要自己去替换存在的,使用起来不是很方便,还要单独写方法。

  • PHP学生
    #7楼    PHP学生
    2025-10-01 11:35:34
    Chrome 0
    @迅睿官方技术专家:结帖结帖结帖结帖结帖结帖结帖结帖结帖