dongzi1209 2013-12-23 12:45
浏览 56
已采纳

Yii IN Query不起作用

I am trying to create a query in yii but its not giving the desired output but throws error

 $name=array('tata','classmate');
    //  $result=  implode(',', $name);
    $mydata='("tata","classmate","adas")';
    $records=Yii::app()->db->createCommand()->select('productName')->from('products')->where
("productName IN :name",array(':name'=>$mydata))->queryColumn();
    var_dump($records);

Error:-MySQL server version for the right syntax to use near ''(\"tata\",\"classmate\",\"adas\")'' at line 3

Note:- $mydata is dynamic

if I try this

"productName IN $mydata" then its working perfectly

  • 写回答

2条回答 默认 最新

  • doubingguan3425 2013-12-23 12:55
    关注

    It appears you are incorrectly building the where clause. Here's a list of how to do WHERE clause with input range:

    // WHERE id=1 or id=2
    where('id=1 or id=2')
    // WHERE id=:id1 or id=:id2
    where('id=:id1 or id=:id2', array(':id1'=>1, ':id2'=>2))
    // WHERE id=1 OR id=2
    where(array('or', 'id=1', 'id=2'))
    // WHERE id=1 AND (type=2 OR type=3)
    where(array('and', 'id=1', array('or', 'type=2', 'type=3')))
    // WHERE `id` IN (1, 2)
    where(array('in', 'id', array(1, 2))
    // WHERE `id` NOT IN (1, 2)
    where(array('not in', 'id', array(1,2)))
    // WHERE `name` LIKE '%Qiang%'
    where(array('like', 'name', '%Qiang%'))
    // WHERE `name` LIKE '%Qiang' AND `name` LIKE '%Xue'
    where(array('like', 'name', array('%Qiang', '%Xue')))
    // WHERE `name` LIKE '%Qiang' OR `name` LIKE '%Xue'
    where(array('or like', 'name', array('%Qiang', '%Xue')))
    // WHERE `name` NOT LIKE '%Qiang%'
    where(array('not like', 'name', '%Qiang%'))
    // WHERE `name` NOT LIKE '%Qiang%' OR `name` NOT LIKE '%Xue%'
    where(array('or not like', 'name', array('%Qiang%', '%Xue%')))
    

    Have a look at the Yii query builder article/guide.

    So, to make it work for you.. try this:

    $mydata = array('tata','classmate', 'adas');
    
    $records = Yii::app()->db->createCommand()
        ->select('productName')
        ->from('products')
        ->where(array('in', 'productName', $mydata)
        ->queryColumn();
    
    var_dump($records);
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 基于作物生长模型下,有限水资源的最大化粮食产量的资源优化模型建立
  • ¥20 关于变压器的具体案例分析
  • ¥15 生成的QRCode圖片加上下載按鈕
  • ¥15 板材切割优化算法,数学建模,python,lingo
  • ¥15 科来模拟ARP欺骗困惑求解
  • ¥100 iOS开发关于快捷指令截屏后如何将截屏(或从截屏中提取出的文本)回传给本应用并打开指定页面
  • ¥15 unity连接Sqlserver
  • ¥15 图中这种约束条件lingo该怎么表示出来
  • ¥15 VSCode里的Prettier如何实现等式赋值后的对齐效果?
  • ¥20 keepalive配置业务服务双机单活的方法。业务服务一定是要双机单活的方式