15

在 Magento 1.7 SOAP APIv2 上,我正在寻找一种方法来获取日期范围以从 SOAP API 检索信息。

$complexFilter = new filters();
$complexFilter->complex_filter = array(
    array(
        'key' => 'created_at',
        'value' => array('key' => 'from', 'value' => '2012-12-17 00:00:00')
    ), 
    array(
        'key' => 'created_at',
        'value' => array('key' => 'to', 'value' => '2013-01-21 12:02:02')
    ), 
);

这似乎是最自然的方法,但只使用了最后一个标准。我还尝试了其他组合,例如复杂过滤器的复杂过滤器,组合它们的不同方式,使用gtand alike 代替fromand co。这些方法中的大多数都产生了相同的结果:只使用里面的最后一个标准。

通过 API 获取日期范围的正确方法是什么?这也可以通过常规过滤器完成吗?如果是这样,如何结合开始和结束日期?

4

3 回答 3

19

我找到了一种更好的方式来查看 Magento 中的代码!幸运的是它是区分大小写的,所以:

$complexFilter->complex_filter = array(
    array(
        'key' => 'CREATED_AT',
        'value' => array('key' => 'from', 'value' => '2012-12-17 00:00:00')
    ), 
    array(
        'key' => 'created_at',
        'value' => array('key' => 'to', 'value' => '2013-01-21 12:02:02')
    ), 
);

把戏做得很漂亮!

于 2014-04-04T22:25:50.377 回答
4

在谷歌搜索了很多之后,我终于得到了一些解释

显然,复杂过滤器的实现不允许存在一个以上的属性。这也是我在测试期间注意到的:只有最后使用的属性会影响结果。因此,我需要找到另一种方式来做我想做的事。看到 Magento 没有提供使用 SOAP API 执行此操作的简单方法,这有点令人遗憾。

我现在使用的最后一种方法是确定最接近我想要的日期。然后只需遍历我想要的日期范围内的结果。这样(至少使用我们的产品数据),我将负载和结果保持在最低限度,并且仍然可以获得所需的产品。

编辑似乎原始链接已关闭,并且该站点不再存在。上面的文字应该是足够的信息。该博客仅显示了一些具有错误实现的代码示例。

于 2013-02-08T13:50:28.940 回答
2

似乎是 mag\sales\order\api\v2.php 中的一个错误

Matlock 在此线程的评论部分为此提供了一个可能的解决方案:http: //www.magentocommerce.com/bug-tracking/issue? issue=8073

于 2013-02-08T23:15:17.647 回答