【求助】组合in的实现问题

浏览:447 发布日期:2014/09/04 分类:求助交流
目的很简单,对用户表的年龄和体重做组合in

目标sql文: select * from user where (age,weight) in ((20,50),(22,60),(23,80));涉及到的表:CREATE TABLE `user` (
  `id` int(11) NOT NULL,
  `age` int(11) NOT NULL,
  `weight` int(11) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
thinkPHP:
方法一:值用数组表达
方法二:值用string表达
代码:$ageWeightList1  = array('(20,50)','(22,60)','(23,80)');
$ageWeightList2  = array(array(20,50),array(22,60),array(23,80));

$result1 = M('User')->where(array('(age,weight)',array('in',ageWeightList1)))->select();
$result2 = M('User')->where(array('(age,weight)',array('in',ageWeightList2)))->select();
两个当然都不行:Sql1:
select * from user where (age,weight) in ('(20,50)','(22,60)','(23,80)');
//error msg: #1241 - Operand should contain 2 column(s)

Sql2:
select * from user where (age,weight) in (Array,Array,Array);
//where不会处理到这一层?
求高手指教!
最佳答案
评论( 相关
后面还有条评论,点击查看>>