Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/62.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
MySQL Where子句不过滤数据_Mysql - Fatal编程技术网

MySQL Where子句不过滤数据

MySQL Where子句不过滤数据,mysql,Mysql,我正在尝试执行以下查询。查询正在工作,但未将数据作为where子句进行筛选。我想不出这个问题 提前谢谢 SELECT case when count(*) = 1 then (select chacc from xxx_1 s inner join xxx_2 d on s.MCHRRN = rrn(d) where d.CHCHNO = dp.CHCHNO and d.CHBKBR = dp.CHBKBR AND d.CHBRCH = dp.CHBRCH AND

我正在尝试执行以下查询。查询正在工作,但未将数据作为where子句进行筛选。我想不出这个问题

提前谢谢

 SELECT
    case when count(*) = 1 then
    (select chacc from xxx_1 s inner join xxx_2 d on s.MCHRRN = rrn(d)
     where d.CHCHNO = dp.CHCHNO and d.CHBKBR = dp.CHBKBR AND d.CHBRCH = dp.CHBRCH AND
     s.MCHPNDT = st.MCHPNDT)
    else 1 end  as is_multiple,
    count(*) as ch_tot,
    dp.CHBRCH,
    dp.CHCHNO,
    dp.CHBKBR,
    SUM(dp.CHCHAM) as chq_amt_tot,
    st.MCHPNDT,
    dp.CHCHST
FROM xxx_3 st
INNER JOIN xxx_4 dp
    ON st.MCHRRN = RRN(dp)
WHERE st.MCHSTAT='P' AND st.MCHAPP IN (40,50) OR (st.MCHAPP = 26 AND st.MCHSVST = 1) AND
    dp.CHDWAC=29 AND dp.CHCHNO=5261 AND st.MCHPNDT BETWEEN 2018001 AND 2018100
GROUP BY dp.CHBRCH,dp.CHCHNO,dp.CHBKBR,dp.CHCHST,st.MCHPNDT
ORDER BY st.MCHPNDT ASC

我想你只需要括号:

WHERE ( (st.MCHSTAT = 'P' AND st.MCHAPP IN (40, 50) ) OR
        (st.MCHAPP = 26 AND st.MCHSVST = 1)
      ) AND
      dp.CHDWAC = 29 AND
      dp.CHCHNO = 5261 AND
      st.MCHPNDT BETWEEN 2018001 AND 2018100

如果您在布尔表达式中同时使用
以及
,我建议您始终使用括号。

您似乎将
以及
混合在一起,而不使用括号来强制执行顺序,因此它完全有可能以您不期望的顺序进行计算。