今天下午需要将两个字段中均不等于0的数据过滤掉,拼条件时用的and,会把其中一个字段为0的数据过滤掉,后来改成用两个字段加起来判断不等于0的方式,又担心一正一负;后来又想加虚拟列(把需要用的列直接加和存储),但因数据条件原因无法加;朋友建议以下方式,但因我的sql比较长,也没采取,然后看来下数据,不可能为负,又改回了加和判断。
SELECT * FROM app_user_login_log a WHERE NOT exists ( SELECT 1 FROM app_user_login_log b WHERE a.LOG_ID = b.log_id and
LOGIN_TYPE = 0 AND LOGIN_RESULT =0
) ;
最后都写好后,就改成了or试了一下,发现成功过滤,得到想要的结果,才想明白为什么,因为用的是不等于
-
jyzb_z<>0 or jyzb_p<>0只要有一个字段不等于0,数据就会显示
-
jyzb_z<>0 and jyzb_p<>0两个字段都不是0的数据才会显示,有一个为0会过滤掉