过滤 Magento 集合但不过滤产品,使用不同的

Filter Magento collection but not products, using distinct(过滤 Magento 集合但不过滤产品,使用不同的)
本文介绍了过滤 Magento 集合但不过滤产品,使用不同的的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

在我的 magento 商店中,我试图从数据库表中检索 youtube 视频列表,但有些视频是重复的.

In my magento store I am trying to retrieve a list of youtube videos from a DB table, some videos are duplicated.

我希望通过使用不同的视频值"来过滤视频,但无法找到有关使用 addFieldToFilter() 使用不同的任何信息

I'm looking to filter videos by using distinct video "value" but can't seam to find any information about using distinct with addFieldToFilter()

// get video collection

$collection = Mage::getModel('video/video')->getCollection();
$collection->addFieldToFilter('provider', 'youtube');

// filter by video value

$collection->addFieldToFilter('value')->distinct(true);

通过删除 $collection->addFieldToFilter('value')->distinct(true); 它可以工作,但会检索所有视频.

By removing $collection->addFieldToFilter('value')->distinct(true); it works, but retrieves all the videos.

推荐答案

你可以试试这个:

$collection->getSelect()->distinct(true);

但这将根据 id 检索不同的值.如果要使用不同的视频值检索视频,则应按值"分组.

But this will retrieve distinct values based on id. If you want to retrieve videos using distinct video values, you should group by "value".

$collection->getSelect()->group('value');

如果要调试执行的查询:

If you want to debug the query executed :

$collection->getSelect()->__toString();

希望能帮到你

这篇关于过滤 Magento 集合但不过滤产品,使用不同的的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

In PHP how can you clear a WSDL cache?(在 PHP 中如何清除 WSDL 缓存?)
failed to open stream: HTTP wrapper does not support writeable connections(无法打开流:HTTP 包装器不支持可写连接)
Stop caching for PHP 5.5.3 in MAMP(在 MAMP 中停止缓存 PHP 5.5.3)
Caching HTTP responses when they are dynamically created by PHP(缓存由 PHP 动态创建的 HTTP 响应)
Memcached vs APC which one should I choose?(Memcached 与 APC 我应该选择哪一个?)
What is causing quot;Unable to allocate memory for poolquot; in PHP?(是什么导致“无法为池分配内存?在 PHP 中?)