我试图在codeigniter中执行过滤搜索功能。我有一个名为products的表,我的系统具有按类别和日期过滤这些产品的功能。我有一个mysql代码,看起来像这样:
SELECT * from products WHERE product_category='Cloth'
INTERSECT
SELECT * from products WHERE ('insert date logic here')
因此它应该从名为products的同一表中返回记录(通过id)。但是,mysql中没有INTERSECT,所以我不知道如何做到这一点。任何帮助将不胜感激!
这是我的代码,仅适用于产品类别的部分
$this->db->limit($limit,$start);
$query = $this->db->query('SELECT * from product_advertised WHERE quantity > 0 AND prodcatid='.$prodcats[0].' LIMIT '.$start.','.$limit);
if(sizeof($prodcats > 1)) {
$query_str = "SELECT * FROM product_advertised WHERE quantity>0 AND ";
$str="";
for($i = 0;$i < sizeof($prodcats);$i++) {
if($i != sizeof($prodcats)-1) {
$str = $str. "prodcatid=".$prodcats[$i]." OR ";
}
else {
$str = $str. "prodcatid=".$prodcats[$i]." LIMIT ".$start.",".$limit;
}
}
$query_str .= $str;
$query = $this->db->query($query_str);
}
if($query->num_rows() > 0) {
foreach($query->result() as $row) {
$data[] = $row;
}
return $data;
}
return false;
答案 0 :(得分:0)
为什么不使用and
?
SELECT *
from products
WHERE product_category = 'Cloth' AND
('insert date logic here');