Mysql 使用IN获取基于多个元键/值对的WP帖子
我在格式化查询以根据两个元值的值从数据库获取帖子列表时遇到一些问题。我使用的是WordPress 4.9.4,我需要使用带有参数的Mysql 使用IN获取基于多个元键/值对的WP帖子,mysql,wordpress,Mysql,Wordpress,我在格式化查询以根据两个元值的值从数据库获取帖子列表时遇到一些问题。我使用的是WordPress 4.9.4,我需要使用带有参数的$wpdb->get_results()和not普通get_posts()函数调用 这是我到目前为止所做的,但是如果我尝试在MySQL查询中包含IN部分,它不会返回任何内容,但至少应该返回一篇文章 global$wpdb; $posts=$wpdb->获取结果( $wpdb->prepare( '选择'.$wpdb->prefix.'posts...'.$wpdb->
$wpdb->get_results()
和not普通get_posts()
函数调用
这是我到目前为止所做的,但是如果我尝试在MySQL查询中包含IN
部分,它不会返回任何内容,但至少应该返回一篇文章
global$wpdb;
$posts=$wpdb->获取结果(
$wpdb->prepare(
'选择'.$wpdb->prefix.'posts...'.$wpdb->prefix.'postETA...''.$wpdb->prefix.'postETA其中'.$wpdb->prefix.'posts.post\u type=%s和'.$wpdb->prefix.'postETA.post\u id='.$wpdb->prefix.'posts.id和'.'('.$wpdb->prefix.'postmeta.meta_key=%s和'$wpdb->prefix.'postmeta.meta_value=%s)和('.$wpdb->prefix.'postmeta.meta_key=%s和'$wpdb->prefix.'posts.post_标题ASC限制%d偏移量%d',
“书”,
“图书流派”,
$GREEP,
“类别”,
'239, 440',
美元限额,
$offset
)
);
上述查询应获取以下位置的所有帖子:
- 在
wp\u posts
- 在
wp\u postmeta
- 在
wp\u postmeta
- 将结果限制为
xyz
xyz的偏移结果
null
值,因此我认为部分可能会与第一个元键/值规则产生某种冲突
如果我删除查询的部分中的,它会得到预期的一切,当然不包括我想要的类别过滤。类别ID是一个ID数组,使用PHP的内爆()将其转换为逗号分隔的字符串。
例如:
- Post
1
的Post\u类型为book
,元键/值对为book\u流派
和Frient
,元键/值对为“category”和440
,因此应使用上述查询包含
- Post
2
的Post\u类型为book
,元键/值对为book\u流派
和小说
,元键/值对为“category”和323
,因此不应使用上述查询包含
您需要两次加入post\u meta
表。下面是一些数据库理论
当您连接表时,理论上,一个临时表包含第一个表中的所有项目,并与第二个表中的所有项目组合在一起,然后创建和筛选。例如,如果您每个帖子只有1个元项目,并且您有3篇帖子,那么您就有了
+-------+----------+
|post_id|post_title|
+-------+----------+
| 1 | 'Post 1' |
| 2 | 'Post 2' |
| 3 | 'Post 3' |
+-------+----------+
及
“理论”临时联接表为:
+---------+------------+----------+----------+-----------+-------------+
|p.post_id|p.post_title|pm.meta_id|pm.post_id|pm.meta_key|pm.meta_value|
+---------+------------+----------+----------+-----------+-------------+
| 1 | 'Post 1' | 10 | 1 | k1 | v1 |
| 1 | 'Post 1' | 11 | 2 | k1 | v2 |
| 1 | 'Post 1' | 12 | 3 | k1 | v3 |
| 2 | 'Post 2' | 10 | 1 | k1 | v1 |
| 2 | 'Post 2' | 11 | 2 | k1 | v2 |
| 2 | 'Post 2' | 12 | 3 | k1 | v3 |
| 3 | 'Post 3' | 10 | 1 | k1 | v1 |
| 3 | 'Post 3' | 11 | 2 | k1 | v2 |
| 3 | 'Post 3' | 12 | 3 | k1 | v3 |
+---------+------------+----------+----------+-----------+-------------+
然后你说:其中p.id=pm.post\u id
并将临时表过滤为:
+---------+------------+----------+----------+-----------+-------------+
|p.post_id|p.post_title|pm.meta_id|pm.post_id|pm.meta_key|pm.meta_value|
+---------+------------+----------+----------+-----------+-------------+
| 1 | 'Post 1' | 10 | 1 | k1 | v1 |
| 2 | 'Post 2' | 11 | 2 | k1 | v2 |
| 3 | 'Post 3' | 12 | 3 | k1 | v3 |
+---------+------------+----------+----------+-----------+-------------+
因此,每个post+元值只有一行。您的查询要求同时包含meta\u key=category
和meta\u key=book\u genera`的行,但这些行不存在
因此,您需要一个两次联接posteta
表的表
您可以通过在加入表时给表添加别名来实现这一点。请原谅我的简化:
SELECT wp_posts.*, pm1.*, pm2.*
FROM
wp_posts
wp_postmeta as pm1
wp_postmeta as pm2
WHERE pm1.post_id = wp_posts.ID
AND pm2.post_id = wp_posts.ID
AND ...etc
这里有两个postmeta表的合并副本,别名为pm1
和pm2
(因为它们不能在查询中同时被称为wp\u postmeta
)
然后,您可以要求:
AND pm1.meta_key = 'category'
AND pm1.meta_value = X
AND pm2.meta_key = 'book_genre'
AND pm2.meta_key IN (123,456)
希望你能把剩下的缝在一起
我还认为,如果你想使用WP_查询,你也可以这样做。这并不清楚,也不需要任何人来破译。如果你的查询需要帮助,那么就给我们一个原始的MySQL查询,并提供输入/输出数据样本。如果你的查询已经运行,并且你需要PHP帮助,那么告诉我们。当我说Query时,我的意思是$wpdb
查询通过WordPress查询方法转变为MySQL查询。我知道这是一个很难问和回答的问题,但我以前没有发现过类似的问题,要么是唯一的,要么我可能会用不同的措辞。要点是我如何以基于两个元键/值对选择帖子的方式编写它。似乎我t写得不正确,支持两个。
AND pm1.meta_key = 'category'
AND pm1.meta_value = X
AND pm2.meta_key = 'book_genre'
AND pm2.meta_key IN (123,456)