看来您正在尝试获取类型为的每个帖子包含一行的结果集
car。似乎您想在帖子中显示每辆汽车的各种属性,并且隐藏在中
postmeta。
专家提示: 除非您完全知道自己要这么做的原因,否则请 不要
SELECt *在软件中使用。尤其是对于包含大量
JOIN操作的查询,
SELECT*将返回许多无意义和冗余的列。
WordPress
postmeta表有一个查询设计技巧。如果要获取特定属性,请执行以下操作:
SELECT p.ID, p.post_title, color.meta_value AS color FROM wp_posts AS p LEFT JOIN wp_postmeta AS color ON p.ID = color.post_id AND 'color' = color.meta_key WHERe p.post_status = 'publish' AND
在执行您要执行的操作时,了解此模式非常重要。此模式是必需的,因为它
postmeta是表的一种特殊类型,称为键值或实体属性值存储。这里发生了什么?一些东西:
- 使用这种模式,您可以为每个帖子获得一行,
posts
表格中有一些列,表格中有特定的属性postmeta
。 - 你是
LEFT JOIN
荷兰国际集团的postmeta
表,所以你仍然可以得到一排,如果属性丢失。 - 您正在为
postmeta
表使用别名。这是postmeta AS color
。 - 在联接的条件下,您将包括
meta_key
(这里是'color' = color.meta_key
)的选择器ON
。 - 您在
SELECt
子句中使用别名来为postmeta.meta_value
项目显示适当的列名。这是color.meta_value AS color
。
一旦习惯了采用这种模式,就可以通过一系列
LEFT JOIN操作将其堆叠起来,以获得许多不同的属性,就像这样。
SELECT wp_posts.ID, wp_posts.post_title, wp_posts.whatever, color.meta_value AS color, transmission.meta_value AS transmission, model.meta_value AS model, brand.meta_value AS brand FROM wp_posts LEFT JOIN wp_postmeta AS color ON wp_posts.ID = color.post_id AND color.meta_key='color' LEFT JOIN wp_postmeta AS transmission ON wp_posts.ID = transmission.post_id AND transmission.meta_key='transmission' LEFT JOIN wp_postmeta AS model ON wp_posts.ID = model.post_id AND model.meta_key='model' LEFT JOIN wp_postmeta AS brand ON wp_posts.ID = brand.post_id AND brand.meta_key='brand' WHERe wp_posts.post_status = 'publish' AND wp_posts.post_type = 'car' ORDER BY wp_posts.post_title
我已经对该查询进行了一系列缩进,以使其更易于查看模式。您可能希望使用其他缩进样式。
很难知道为什么您的查询中存在性能问题。可能是因为您收到了包含所有
INNERJOIN随后被过滤的所有操作的组合爆炸。但是无论如何,您显示的查询可能不返回任何行。
如果仍然遇到性能问题,请尝试
postmeta在
(post_id, meta_key,meta_value)列上创建复合索引。如果要创建WordPress插件,则可能是在插件安装时要做的工作。



