在我的 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 集合但不过滤产品,使用不同的的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!
在 SELECT(MYSQL/PHP) 中加入 2 个表Joining 2 tables in SELECT(MYSQL/PHP)(在 SELECT(MYSQL/PHP) 中加入 2 个表)
如何使<option selected=“selected">由How to make lt;option selected=quot;selectedquot;gt; set by MySQL and PHP?(如何使lt;option selected=“selectedgt;由 MySQL 和 PHP 设置?)
使用 PHP 中的数组自动填充选择框Auto populate a select box using an array in PHP(使用 PHP 中的数组自动填充选择框)
PHP SQL SELECT where like search item with multiple wordsPHP SQL SELECT where like search item with multiple words(PHP SQL SELECT where like search item with multiple words)
json_encode 从 MSSQL-SELECT 产生 JSON_ERROR_UTF8json_encode produce JSON_ERROR_UTF8 from MSSQL-SELECT(json_encode 从 MSSQL-SELECT 产生 JSON_ERROR_UTF8)
MySQL ORDER BY rand(),名称 ASCMySQL ORDER BY rand(), name ASC(MySQL ORDER BY rand(),名称 ASC)