当前位置: 首页 > 面试题库 >

使用很多内部连接来改进查询,键/值表wp_postmeta

令狐宏浚
2023-03-14
问题内容

与正在执行以下查询的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的架构在这里。


问题答案:

看来您正在尝试获取类型为的每个帖子包含一行的结果集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 JOIN荷兰国际集团的postmeta表,所以你仍然可以得到一排,如果属性丢失。
  3. 您正在为postmeta表使用别名。这是postmeta AS color
  4. 在联接的条件下,您将包括meta_key(这里是'color' = color.meta_key)的选择器ON
  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随后被过滤的所有操作的组合爆炸。但是无论如何,您显示的查询可能不返回任何行。

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



 类似资料:
  • 我相信postgresql可以更快地处理我的查询,但每次修改它的尝试都会使它变慢! 我有两张桌子: < li >统计数据(id,field1,[...],field10) < li >几何图形(id,geom) 我在以下位置创建了索引: < li>statistics.id < li>geometry.id < Li > geometry(ST _ x(ST _ centroid(ST _ tra

  • 我有2个具有多对多关系的实体User和AcCountBase。我需要从连接表中选择所有具有选定用户ID的AcCountBase对象。我尝试了一些连接查询,但不起作用。

  • 我试图在JPA2中进行一些查询,但它不断调用另一个查询来获取依赖项的信息 我的课程是: 我把这样的查询称为: 但我的结果是:

  • 我是spring boot新手,需要关于具有多个内部连接的自定义JPA查询的帮助。基本上,我需要将以下SQL查询转换为JPA查询: 下面是代码结构: 公司实体 软件库 认证计数信号I mpl

  • 问题内容: 我有两个要与之进行内部联接的表。 一个是主键为的表。 另一个表是外键在哪里。也有一个列,其中where是表的外键。 我正在尝试汇总一个ActiveRecord查询,在这里我可以选择N天前或之前创建的所有用户,并且其中任何一个都没有等于特定ID的用户。我试图做这样的事情: 此查询字段超过30,000个结果,这是不正确的,因为Users表仅具有12,000行。 我到底在做什么错? 问题答案

  • 我正在使用hibernate为一个项目连接到我的数据库。 我想有一个查询,从我的数据库中获得产品与特定语言的描述和名称。我拥有的参数是该语言的简称,因此首先我必须获得该语言的id,然后获得所需语言的文本。 我尝试了下面的hql查询,没有成功。