mysql搜索中的双重数据

时间:2012-12-08 16:43:41

标签: php mysql

任何人都可以告诉我这个

有什么问题

$paramcari是需要搜索的值,它应该是a.status不是0但不是2的数据,但是过滤器不起作用,输出总是显示所有状态是否是0,0或2 ...我错过了什么?

$sql="select a.*, b.*, d.*,  e.*, f.*, j.*, k.*, DATE_FORMAT(a.tgldaftar,'%d %b %Y %H:%i') as tgldaftar,
      DATE_FORMAT(a.tglkeluar,'%d %b %Y %H:%i') as tglkeluar , i.*
      from daftar a
      INNER JOIN  pasien  b ON a.noRM=b.noRM 
      INNER JOIN  ranjang d ON a.idranjang=d.idranjang 
      INNER JOIN  ruang e ON d.idruang=e.idruang 
      INNER JOIN  kelas  j ON e.idkelas=j.idkelas 
      INNER JOIN  instalasi  k ON e.idinstalasi=k.idinstalasi
      INNER JOIN (select idjenispasien , jenispasien  from jenispasien ) f ON a.idjenispasien=f.idjenispasien 
      INNER JOIN rujukan i ON a.idrujukan=i.idrujukan and a.status !=0 and a.status != 2";

if($paramcari != ""){
    $sql.=" and b.nama like '%$paramcari%'  ";
    $sql.=" or j.namakelas like '%$paramcari%'  ";
    $sql.=" or e.namaruang like '%$paramcari%'  ";
    $sql.=" or b.idRM like '%$paramcari%'  ";
    $sql.=" or i.namars like '%$paramcari%'  ";
    $sql.=" or a.nodaftar like '%$paramcari%'  ";
}   

$sql.="ORDER BY a.tgldaftar ASC limit  $start,15   ";   

1 个答案:

答案 0 :(得分:1)

您的搜索条件and a.status !=0 and a.status != 2会附加到最后一个内部联接条件。它应该在where条件下。将最后一次加入更改为

INNER JOIN rujukan i ON a.idrujukan=i.idrujukan
where a.status !=0 and a.status != 2";

同时在搜索条件中添加大括号,因为and的优先级高于or

if($paramcari != ""){
    $sql.=" and (b.nama like '%$paramcari%'  ";
    ...
    $sql.=" or a.nodaftar like '%$paramcari%') ";
}