- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要帮助来完成 Woocommerce 产品列表的 SQL 查询。我需要这个用于 wpdatatable sql 输入。
我搜索了示例代码并改编了找到的代码:
SELECT
p.ID,
p.post_title,
p.post_content,
p.post_excerpt,
t.name AS product_category,
t.term_id AS product_id,
tt.term_taxonomy_id AS tt_term_taxonomia,
tr.term_taxonomy_id AS tr_term_taxonomia,
MAX(CASE WHEN pm1.meta_key = '_price' then pm1.meta_value ELSE NULL END) as price
FROM wp_posts p
LEFT JOIN wp_postmeta pm1 ON pm1.post_id = p.ID
LEFT JOIN wp_term_relationships AS tr ON tr.object_id = p.ID
JOIN wp_term_taxonomy AS tt ON tt.taxonomy = 'product_cat' AND tt.term_taxonomy_id = tr.term_taxonomy_id
JOIN wp_terms AS t ON t.term_id = tt.term_id
WHERE p.post_type in('product', 'product_variation') AND p.post_status = 'publish'
GROUP BY p.ID,p.post_title
它可以工作,但没有可变产品的产品行。它仅显示产品的主要变体。
例子:产品牛排:我有 6 种不同的牛排作为自己的产品,价格不同,重量特征也不同。通过我的 SQL 查询,我只能看到没有变化和变化价格的主要产品“牛排”。
表 wp_Posts
id | post_title | post_type | post_parent | post_name | regular_price |-----+--------------------------------+-------------------+-------------+-----------+---------------|4113 | Steaks | product | 0 |4119 | Steaks-Lungenbraten Steak 125g | product_variation | 4113 | steaks_4 |6 |4120 | Steaks-Hüftsteak 200g | product_variation | 4113 | steaks_5 |4,4 |4121 | Steaks-Flankensteak 600g | product_variation | 4113 | steaks_6 |8,4 |
表 wp_postmeta-
Post_ID |meta_key | meta_value |--------+----------------+----------------------------+---------4113 | | 4119 | attribute_pa_steaks | lungenbraten-steak |4119 | _price. | 6 |4120 | attribute_pa_steaks | hueftsteak |4120 | _price. | 4,4 |4121 | attribute_pa_steaks | flanksteak |4121 | _price. | 8,4 |
wp_term_relationship
object_id. | term_taxonomy_id. | term_order |------------+-------------------+------------+4113 | 6 | 0 |4113 | 296 | 0 |4113 | 297 | 0 |4113 | 298 | 0 |
wp_term_taxonomy
term_taxonomy_id. | term_id | taxonomy | description. | parent |count |------------------+----------+-------------+--------------+--------+------+296 | 296 | pa_steaks | | 0 | 1. |297 | 297 | pa_steaks | | 0 | 1. |298 | 298 | pa_steaks | | 0 | 1. |
wp_terms
term_id | name | slug | term_group | ------------+--------------------+--------------------+------------+296 | Flanksteak | flanksteak | 0 |297 | Hüftsteakk | hueftsteak | 0 |298 | Lungenbraten Steak | Lungenbraten-steak | 0 |
最佳答案
您的查询无效,因为选择列表与 GROUP BY
不匹配。即使您的 DBMS 有缺陷并且没有引发错误,我也不建议使用这样的查询。它的结果可能是任意的(例如 MySQL 中的情况)。编写一个查询,明确您真正想要选择的数据。
因为您只需要键/值表 wp_postmeta
中的一个值,所以您不需要聚合:
SELECT
p.id,
p.post_title,
p.post_content,
p.post_excerpt,
t.name AS product_category,
t.term_id AS product_id,
tt.term_taxonomy_id AS tt_term_taxonomia,
tr.term_taxonomy_id AS tr_term_taxonomia,
pm1.meta_value AS price
FROM wp_posts p
LEFT JOIN wp_postmeta pm1 ON pm1.post_id = p.ID AND pm1.meta_key = '_price'
JOIN wp_term_relationships AS tr ON tr.object_id = p.ID
JOIN wp_term_taxonomy AS tt ON tt.taxonomy = 'product_cat'
AND tt.term_taxonomy_id = tr.term_taxonomy_id
JOIN wp_terms AS t ON t.term_id = tt.term_id
WHERE p.post_type in('product', 'product_variation') AND p.post_status = 'publish'
ORDER BY
CASE WHEN p.post_parent = 0 THEN id else post_parent END,
CASE WHEN p.post_parent = 0 THEN 1 else 2 END;
关于mysql - 查询所需的支持,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59306757/
我有一个依赖于包 B 的包 A。当包 A 中的代码运行并访问包 B 中的类时,包 B 的状态将被解析 (4),而不是 Activity (32) 和包 B 的激活器也没跑好。我认为 bundle B
这个问题在这里已经有了答案: How to remove the space between inline/inline-block elements? (41 个回答) 关闭 7 年前。
我正在尝试使用 Java OpenAL 库。我在导入名为 libsoft_oal.so 的 native 库时遇到问题。 Java OpenAL 依赖于 OpenAL 软实现。我尝试根据他们在 git
我正在尝试启动我的应用程序。是一个 unicorn +工头+sinatra的应用。 这是我的 config.ru 文件: require "rubygems" require "sinatra" Bu
我有一个下拉列表,其中包含一些从数据库表中检索的值,我想要的是当单击按钮时它应该只获得选项标签的中间值,但只有那些类名为“get_this”的选项标签并离开那些选项,如果他们没有这个类 预期输出:值
我有一个index.php文件,需要一个通用的head.php文件,head.php文件中有几个Javascript文件,当这样尝试时,代码在源代码中看起来很好,但文件却不是实际上对文档做任何事情。
有人能帮帮我吗? 我已经像这样运行了 imsmod: $ insmod /data/mm/mmdev.ko epoll_rate=100 但是我得到一个错误: insmod: init_module
是否有键盘快捷键或插件可以在 Notepad++ 中打开 PHP 所需或包含的文件?我知道,在 Dreamweaver 中,执行此操作的命令是 Ctrl+D,但我似乎无法在 Notepad++ 中找到
我已经用 js 设置了一个显示/隐藏 div,但我很难弄清楚如何一次显示一个 div。目前发生的情况是,除非我再次单击原始链接来关闭该 div,否则每个 div 都会显示。 http://www.li
当我尝试将未分配的辅助分片分配给节点时出现错误。 { "error": { "root_cause": [ { "type": "remote_transpor
我正在构建一个 C++ 应用程序,使用 Netbeans 6.9 作为我的 IDE。我有一个 C++ 库,它是一个纯 C 库的包装器。 我已将文件正确添加到项目中(使用添加库文件选项)。这是 g++
我是一名优秀的程序员,十分优秀!