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 下图接收小电路,谁知道原理
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题
  • ¥15 matlab中使用gurobi时报错
  • ¥15 这个主板怎么能扩出一两个sata口
  • ¥15 不是,这到底错哪儿了😭
  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么