gpt4 book ai didi

mysql - 使用大量与 wp_postmeta(键/值表)的内部联接来改进查询

转载 作者:行者123 更新时间:2023-11-29 23:29:16 27 4
gpt4 key购买 nike

我正在使用一个正在执行以下查询的wordpress网站,但我看到这个查询正在执行许多内部联接,并且该网站需要很长时间才能加载并且出现故障,并且我一直在尝试创建一个生成的查询结果相同,但尚未成功

我想知道什么是更好的方法

SELECT *
FROM wp_posts
INNER JOIN wp_postmeta color ON wp_posts.ID = color.post_id
INNER JOIN wp_postmeta transmission ON wp_posts.ID = transmission.post_id
INNER JOIN wp_postmeta model ON wp_posts.ID = model.post_id
INNER JOIN wp_postmeta brand ON wp_posts.ID = brand.post_id

AND color.meta_key = 'color'
AND color.meta_value = 'red'
AND transmission.meta_key = 'transmission'
AND transmission.meta_value = 'auto'
AND model.meta_key = 'model'
AND model.meta_value = 'model'
AND brand.meta_key = 'brand'
AND brand.meta_value = 'brand'

AND wp_posts.post_status = 'publish'
AND wp_posts.post_type = 'car'
ORDER BY wp_posts.post_title

这是解释输出。

+----+-------------+-----------+--------+-----------------------------+----------+---------+------------------------+------+----------------------------------------------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+-------------+-----------+--------+-----------------------------+----------+---------+------------------------+------+----------------------------------------------+
| 1 | SIMPLE | color | ref | post_id,meta_key | meta_key | 768 | const | 629 | Using where; Using temporary; Using filesort |
| 1 | SIMPLE | wp_posts | eq_ref | PRIMARY,type_status_date,ID | PRIMARY | 8 | tmcdb.color.post_id | 1 | Using where |
| 1 | SIMPLE | brand | ref | post_id,meta_key | post_id | 8 | tmcdb.wp_posts.ID | 4 | Using where |
| 1 | SIMPLE | transmission | ref | post_id,meta_key | post_id | 8 | tmcdb.color.post_id | 4 | Using where |
| 1 | SIMPLE | model | ref | post_id,meta_key | post_id | 8 | tmcdb.transmission.post_id | 4 | Using where |
+----+-------------+-----------+--------+-----------------------------+----------+---------+------------------------+------+----------------------------------------------+

Wordpress schema here.

最佳答案

您似乎正在尝试获取每篇文章一行 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 /* etc etc */

在做你想做的事情时理解这种模式是非常重要的。这种模式是必需的,因为 postmeta 是一种特殊类型的表,称为 店铺。这里发生了什么?一些事情:

  1. 使用此模式,您可以为每个帖子获取一行,其中包含 posts 表中的一些列以及 postmeta 表中的特定属性。
  2. 您正在LEFT JOINpostmeta 表,因此即使缺少属性,您仍然会得到一行。
  3. 您正在使用 postmeta 表的别名。这是postmeta AS 颜色
  4. 您将在连接的 ON 条件中包含 meta_key 选择器(此处为 'color' = color.meta_key)。
  5. 您在 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

我对此查询进行了一系列缩进,以便更轻松地查看模式。您可能更喜欢不同的缩进样式。

很难知道为什么您的问题中的查询会出现性能问题。这可能是因为您遇到了随后被过滤的所有 INNER JOIN 操作的组合爆炸。但无论如何,您显示的查询可能没有返回任何行。

如果您仍然遇到性能问题,请尝试在 (post_id, meta_key, meta_value) 列的 postmeta 上创建复合索引。如果您要创建 WordPress 插件,这可能是在插件安装时完成的工作。

关于mysql - 使用大量与 wp_postmeta(键/值表)的内部联接来改进查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26690036/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com