自定义SQL,用于从排除类别中返回id的类别数组中发布帖​​子。怎么了?

时间:2015-03-04 09:35:01

标签: php mysql sql wordpress customization

我有这个问题:

 $querystr = "SELECT  $wpdb->posts.* FROM  $wpdb->posts 
INNER JOIN  $wpdb->term_relationships 
      ON ($wpdb->posts.ID = $wpdb->term_relationships.object_id) 
INNER JOIN  $wpdb->postmeta 
      ON ( $wpdb->posts.ID = $wpdb->postmeta.post_id ) 
INNER JOIN $wpdb->postmeta AS mt1 
      ON ( $wpdb->posts.ID = mt1.post_id ) 
WHERE 1=1 AND $wpdb->term_relationships.term_taxonomy_id 
IN (".implode(',',array_unique($categories)).") 
AND $wpdb->posts.post_type = 'post' 
AND ($wpdb->posts.post_status = 'publish') 
AND ( ( $wpdb->postmeta.meta_key = 'joke_type' 
AND CAST($wpdb->postmeta.meta_value AS CHAR) = '".$type."' ) 
AND ( mt1.meta_key = 'joke_rating' AND CAST(mt1.meta_value AS SIGNED) >= '3' ) ) 
GROUP BY $wpdb->posts.ID ORDER BY $wpdb->posts.ID DESC";

当我打印字符串时会正确计算,但是在执行时它会从此选择中未包含的类别中抛出ID,例如类别58,我已经检查了10000次并且我确定它不在SQL字符串中。我也在数据库中运行了这个,结果相同......我可以看到不在这些类别中的帖子。

我在这里做错了什么?

这是查询字符串:

SELECT wp_njkf_posts.* FROM wp_njkf_posts 
INNER JOIN wp_njkf_term_relationships 
      ON (wp_njkf_posts.ID = wp_njkf_term_relationships.object_id) 
INNER JOIN wp_njkf_postmeta 
      ON ( wp_njkf_posts.ID = wp_njkf_postmeta.post_id ) 
INNER JOIN wp_njkf_postmeta AS mt1 
      ON ( wp_njkf_posts.ID = mt1.post_id ) 
WHERE 1=1 
AND wp_njkf_term_relationships.term_taxonomy_id 
         IN (
139,133,45,135,38,40,69,85,112,123,53,55,81,36,121,95,83,9,79,35,104,
60,11,101,63,30,122,68,12,98,32,125,124,119,88,129,61,113,108,100,99,   

126,140,131,13,14,105,15,16,49,43,41,74,114,62,94,65,141,17,115,51,18,
19,72,109,93,87,56,20,111,67,34,66,82,21,22,84,75,71,120,46,118,
31,86,70,23,90,110,78,92,24,91,89,73,47,64,29,107,97,130,
1,44,59,76,77,80,54,25) 
    AND wp_njkf_posts.post_type = 'post' 
    AND (wp_njkf_posts.post_status = 'publish') 
    AND ( ( wp_njkf_postmeta.meta_key = 'joke_type' 
    AND CAST(wp_njkf_postmeta.meta_value AS CHAR) = 'joke' ) 
    AND ( mt1.meta_key = 'joke_rating' 
    AND CAST(mt1.meta_value AS SIGNED) >= '3' ) ) 
GROUP BY wp_njkf_posts.ID ORDER BY wp_njkf_posts.ID DESC

LATER EDIT,也试过这个。这将返回0行:

    SELECT p . * 
    FROM wp_njkf_posts p, wp_njkf_term_relationships r, wp_njkf_postmeta pm
    WHERE p.ID = r.object_id
    AND p.ID = pm.post_id
    AND r.term_taxonomy_id
    IN ( 139, 133, 45, 135, 38, 40, 69, 85, 112, 123, 53, 55, 81, 36, 121, 95, 83, 9, 79, 35, 
104, 60, 11, 101, 63, 30, 122, 68, 12, 98, 32, 125, 124, 119, 88, 129, 61, 113, 108, 100, 99, 
126, 140, 131, 13, 14, 105, 15, 16, 49, 43, 41, 74, 114, 62, 94, 65, 141, 17, 115, 51, 18, 19, 
72, 109, 93, 87, 56, 20, 111, 67, 34, 66, 82, 21, 22, 84, 75, 71, 120, 46, 118, 31, 86, 70, 23, 
90, 110, 78, 92, 24, 91, 89, 73, 47, 64, 29, 107, 97, 130, 1, 44, 59, 76, 77, 80, 54, 25 ) 
    AND p.post_type =  'post'
    AND p.post_status =  'publish'
    AND (
    pm.meta_key =  'joke_type'
    AND CAST( pm.meta_value AS CHAR ) =  'joke'
    AND pm.meta_key =  'joke_rating'
    AND CAST( pm.meta_value AS SIGNED ) >=  '3'
    )
    GROUP BY p.ID
    ORDER BY p.ID DESC 
    LIMIT 0 , 30

1 个答案:

答案 0 :(得分:0)

问题发生在我的数据库中。它已经解决了。该查询作为第一个变体正常工作。