简体   繁体   English

Mysql Query返回0结果

[英]Mysql Query returning 0 results

Given the values in these 2 rows, why does my query return 0 rows and how can the query be rewritten to work properly? 给定这两行中的值,为什么我的查询返回0行,如何重写查询才能正常工作?

meta_id post_id meta_key   meta_value
   1422      73 wpcf-milk      22
   1423      73 wpcf-mw        -7

SQL Query: SQL查询:

   SELECT * FROM wp_postmeta
    WHERE post_id = 73 
    AND ( meta_key = 'wpcf-mw' AND meta_value BETWEEN -8 AND 200 )
    AND ( meta_key = 'wpcf-milk' AND meta_value BETWEEN 20 AND 200 )
SELECT * FROM wp_postmeta 
WHERE post_id = 73 
  AND (( meta_key = 'wpcf-mw' AND meta_value BETWEEN -8 AND 200 ) 
  **OR** ( meta_key = 'wpcf-milk' AND meta_value BETWEEN 20 AND 200 ))

Change AND by OR. 通过OR更改AND。

There are essentially two ways of doing this. 基本上有两种方法可以做到这一点。 One is roughly as follows: 一个大致如下:

SELECT post_id
     , MAX(CASE WHEN meta_key = 'wpcf-milk' THEN meta_value END) wpcf_milk
     , MAX(CASE WHEN meta_key = 'wpcf-mw' THEN meta_value END) wpcf_mw 
  FROM wp_postmeta 
 GROUP 
    BY post_id 
HAVING wpcf_milk BETWEEN 20 AND 200 
   AND wpcf_mw BETWEEN -8 AND 200;

The other approach involves OUTER JOINs and is slightly faster, but slightly more tedious to type out - so I'll leave it to others. 另一种方法涉及OUTER JOIN并且速度稍快,但输入时稍微繁琐一些 - 所以我会把它留给其他人。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM