- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在为 reporting plugin 创建一个插件扩展.当前插件创建各种报告,包括基于每个产品的最畅销产品报告。
我需要重新创建此设置以根据变体显示顶级产品。需要的字段是产品名称、SKU、销售数量、销售总额。
如何获取产品变体的数据?
以下是我当前的代码。
SQL查询和数据处理:
$phoen_product_query = "
SELECT
posts.post_title AS product_name,
meta.meta_key as mkey,
meta.meta_value as product_value,
posts.ID AS ID
FROM {$wpdb->posts} AS posts
LEFT JOIN {$wpdb->postmeta} AS meta
ON posts.ID = meta.post_id
WHERE
posts.post_status IN ( 'publish','private' )
AND posts.post_type IN ( 'product' )
AND meta.meta_key IN ( 'total_sales' ,'_price' ,'post_views_count', '_sku')
ORDER BY
posts.ID ASC,
meta.meta_key ASC
";
$phoen_product_data = $wpdb->get_results( $phoen_product_query,ARRAY_A);
foreach($phoen_product_data as $key1 => $valuee){
if(!isset( $phoen_top_products[$valuee['ID']])){
$phoen_top_products[$valuee['ID']] = Array();
$phoen_top_products[$valuee['ID']] = Array(
"produc_total" => 0,
"product_price" => 0,
"product_count" => 0,
"product_views" => 0
);
}
switch ($valuee['mkey']) {
case "_sku":
$phoen_top_products[$valuee['ID']]["product_sku"] = $valuee['product_value'];
break;
case "_price":
$phoen_top_products[$valuee['ID']]["product_price"] = $valuee['product_value'];
break;
case "post_views_count":
$phoen_top_products[$valuee['ID']]["product_views"] = $valuee['product_value'];
break;
case "total_sales":
$phoen_top_products[$valuee['ID']]["product_count"] = $valuee['product_value'];
$phoen_top_products[$valuee['ID']]["produc_total"] = $valuee['product_value'] * $phoen_top_products[$valuee['ID']]["product_price"];
$phoen_top_products[$valuee['ID']]["product_name"] = $valuee['product_name'];
$phoen_top_products[$valuee['ID']]["ID"] = $valuee['ID'];
break;
default:
break;
}
}
管理模块:
<table class="table table-striped table-bordered" id="phoen_top_product_table">
<thead>
<tr>
<th><?php _e( 'Product Name', 'advanced-reporting-for-woocommerce' ); ?></th>
<th><?php _e( 'SKU', 'advanced-reporting-for-woocommerce' ); ?></th>
<th><?php _e( 'Qty', 'advanced-reporting-for-woocommerce' ); ?></th>
<th><?php _e( 'Amount', 'advanced-reporting-for-woocommerce' ); ?></th>
</tr>
</thead>
<tbody>
<?php
$phoen_repot_product=array();
$phoen_product_count=0;
for($i=0; $i<count($phoen_top_products); $i++)
{
if($phoen_get_product_val!='View All')
{
if($phoen_product_count<$phoen_get_product_val)
{
?>
<tr class="phoen_top_product_tr">
<td>
<?php $phoen_product_title=isset($phoen_top_products[$i]['product_name'])?$phoen_top_products[$i]['product_name']:'';
echo $phoen_product_title; ?>
</td>
<td>
<?php $phoen_product_sku=isset($phoen_top_products[$i]['product_sku'])?$phoen_top_products[$i]['product_sku']:'';
echo $phoen_product_sku; ?>
</td>
<td>
<?php
$phoen_product_quentity=isset($phoen_top_products[$i]['product_count'])?$phoen_top_products[$i]['product_count']:'';
echo $phoen_product_quentity;
?>
</td>
<td>
<?php
$phoen_total_product_price=isset($phoen_top_products[$i]['produc_total'])?$phoen_top_products[$i]['produc_total']:'';
echo get_woocommerce_currency_symbol().($phoen_total_product_price);
?>
</td>
</tr>
<?php
$phoen_repot_product[$i]= array(
'name'=>$phoen_product_title,
'sku'=>$phoen_product_sku,
'product_count'=>$phoen_product_quentity,
'amount'=>$phoen_total_product_price
);
}
$phoen_product_count++;
}else{
?>
<tr class="phoen_top_product_tr">
<td>
<?php $phoen_product_title=isset($phoen_top_products[$i]['product_name'])?$phoen_top_products[$i]['product_name']:'';
echo $phoen_product_title; ?>
</td>
<td>
<?php $phoen_product_sku=isset($phoen_top_products[$i]['product_sku'])?$phoen_top_products[$i]['product_sku']:'';
echo $phoen_product_sku; ?>
</td>
<td>
<?php
$phoen_product_quentity=isset($phoen_top_products[$i]['product_count'])?$phoen_top_products[$i]['product_count']:'';
echo $phoen_product_quentity;
?>
</td>
<td>
<?php
$phoen_total_product_price=isset($phoen_top_products[$i]['produc_total'])?$phoen_top_products[$i]['produc_total']:'';
echo get_woocommerce_currency_symbol().($phoen_total_product_price);
?>
</td>
</tr>
<?php
$phoen_repot_product[$i]= array(
'name'=>$phoen_product_title,
'sku'=>$phoen_product_sku,
'product_count'=>$phoen_product_quentity,
'amount'=>$phoen_total_product_price
);
}
}
$phoen_product_file = fopen('phoen-repot-product.csv', 'w');
fputcsv($phoen_product_file, array('Product Name', 'SKU', 'Qty', 'Amount'));
foreach ($phoen_repot_product as $phoen_product_row)
{
fputcsv($phoen_product_file, $phoen_product_row);
}
fclose($phoen_product_file);
?>
</tbody>
最佳答案
在您的数据库查询中,您只是忘了调用 post_type
,例如 'product_variation'
。
您可以替换这一行:
AND posts.post_type IN ( 'product' )
由此:
AND posts.post_type IN ( 'product','product_variation' )
或者这个(更短):
AND posts.post_type LIKE 'product%'
您还将获得所有产品变体数据。 我已经测试了您的代码并且它有效。
(我只有“post_views_count”为空,因为我认为这是一个自定义字段)。
关于php - WooCommerce:获取 SQL 查询中产品变体的总销售额,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46259218/
我正在创建一个连接到 firebase 的应用程序。但我面临一些问题。当同步我的 gradle 文件时,我收到此警告 WARNING: API 'variant.getMergeResources()
想知道是否有任何方法可以将变体分配给自定义 radio 输入?我想为 2 天、3 天和标准运输设置不同费率的分级运输。我可以使用变体来做到这一点,但下拉菜单对我不起作用。我想要日期信息和日期选择器,以
我是 Haskell 的新手。鉴于 Haskell 的整个前提是函数将始终返回相同的值,我希望有某种方式,例如在编译时计算常量的斐波那契值,就像我可以在 C++ 中使用模板元编程一样,但我不知道该怎么
我是 OCaml 的新手,但过去两天一直在工作,以便更好地了解如何使用它。我最近做了很多事情,但有些事情阻碍了我前进。 我正在尝试在 OCaml 中实现 evaexpr。使用这种语言非常容易,你会说:
我有一个使用一些typedef的std::variant的代码库。 最初,它们是不同的类型,但现在它们像下面的示例一样重叠 typedef int TA; typedef int TB; std::v
鉴于此: data Foo = Bar { name :: String } | Baz { nickname :: String } 函数 name 和 nickname 似乎都是 Foo -> S
嘿,我猜这可能相当微不足道,但我很难找到答案或弄清楚它。 我正在尝试创建一个带有任意间距的彩色方 block 网格。这本身很容易做到,特别是因为我只需要九个正方形。但是虽然我看着我完成的代码,我不禁觉
我有 woocommerce 设置,其中包含产品和这些产品的变体。当我更改变化时(例如,产品的尺寸(340克或900克),我希望它在页面上动态更新价格,以便人们可以看到两种尺寸之间的价格差异。目前,我
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
在我的一节课上,我被问到这是一个脑筋急转弯,但我无法弄明白(这不是家庭作业问题,只是其中一位助教给我们的一个脑筋急转弯让我们思考)。 给你一根杆,上面有 n 个要切割的点,例如 [1,5,11],以及
关于 CRP如果我想实现它的细微变化(使用模板模板参数),我会得到一个编译错误: template class Derived> class Base { public: void Call
我正在创建一个 woocommerce 主题,并且我有产品变体,即显示在产品详细信息页面上的尺寸,但问题是我想通过使用产品 ID 在我的自定义 php 页面中获取所有变体,任何人都可以帮助我。 提前致
我正在使用 Ionic 开发移动应用程序,我必须与 Twitter API 连接。 所以我使用 ng-cordova 和 $cordovaAuth .但是当我这样做时: $cordovaOauth.t
这里的网站有一个音乐播放器http://www.numberonedesigns.com/ubermusic.com/ ...当点击下一个按钮并随机突出显示时,它不会正确随机化。它总是返回到播放列表中
我有列 sql 变体,其含义如下:100, 150, D1我正在尝试根据特定逻辑将列中的所有数字转换为字母(例如 D1)以防万一。但是 150 有空格并且 CASE WHEN 不起作用。 这是我正在使
有没有一种快速方法可以用从匹配模式派生的数据替换所有出现的某些模式? 例如,如果我想将字符串中出现的所有数字替换为用 0 填充到固定长度的相同数字。 在本例中,如果长度为 4,则 ab3cd5 将变为
我目前正在寻找生成具有特定位数的数字列表,我的代码当前如下: | Python 2.7 | import itertools inp = raw_input('Number of digits to
我正在对类型系统进行研究。对于这项工作,我正在研究流行语言中变体、结构子类型、通用多态性和存在多态性的用法。像 heskell、ocaml 这样的功能性语言提供了这样的功能。但我想知道像 C++ 这样
这是 variant.hpp 文件中的相关代码(可在此处找到 http://www.boost.org/doc/libs/1_49_0/boost/variant/variant.hpp) templ
您好,我有两个具有多对多关系的表和一个联结表。简而言之,具有不同属性的产品也随之增加了价格。为了更清楚地说明我是产品和属性表。 +-------------+------------+--------
我是一名优秀的程序员,十分优秀!