我需要在SQL或php中选择MySQL帮助。 我的情况: 我有一个像这样的SQL表
ID | organization_ID | Investment | investment_curr | paid | paid_curr | effective_from | Effective_to
1 | 195001 | 5000 | EUR | NULL | EUR | 2010-06-23 | NULL
2 | 195001 | NULL | EUR | 5000 | EUR | 2010-06-23 | NULL
3 | 195001 | 2000 | SKK | NULL | SKK | 2007-08-01 | 2010-06-22
4 | 195001 | NULL | SKK | 2000 | SKK | 2007-08-01 | 2010-06-22
现在我有php select(joomla),当按organization_id
选择值时$query_rpo_organization_equity_entries = $db->getQuery(true);
$query_rpo_organization_equity_entries
->select(array('organization_id',
'investment_amount',
'investment_currency',
'paid_amount',
'paid_currency',
'effective_from',
'effective_to'
))
->from($db->quoteName('rpo_organization_equity_entries'))
->where($db->quoteName('organization_id') . ' = '. $db->quote($rpo_id))
->order(($db->quoteName('effective_to') . ' IS NOT NULL'), $db->quoteName('effective_to') . ' DESC ');
$db->setQuery($query_rpo_organization_equity_entries);
$query_rpo_organization_equity_entries = $db->loadObjectList();
然后我打电话给foreach
foreach($query_rpo_organization_equity_entries as $rpo_organization_equity_entries) {}
一切正常,但不是我需要的方式。这个foreach
返回4个数组,但我需要按行“effective_from”和“effective_to”合并/组合行(如果它们具有相同的值。和organization_id ofcourse)。
因此,我将行与ID 1和2以及ID为3和4的行组合在一起,而不是4个数组,我只有2个这样的组合/合并数组
XY | 195001 | 5000 | EUR | 5000 | EUR | 2010-06-23 | NULL
XY | 195001 | 2000 | SKK | 2000 | SKK | 2007-08-01 | 2010-06-22
我应该怎么做?最好解决SQL然后在php?
THX
答案 0 :(得分:0)
使用GROUP BY函数可以使用MySQL实现您希望获得的结果。
在Joomla docs中,他们对此很清楚。您可以在对象上使用group()函数。
//Example
$query
->select( array('catid', 'COUNT(*)') )
->from($db->quoteName('#__content'))
->group($db->quoteName('catid'));
在您的情况下,您可能希望将代码更改为:
$query_rpo_organization_equity_entries = $db->getQuery(true);
$query_rpo_organization_equity_entries
->select(array('organization_id',
'MAX(investment_amount)',
'investment_currency',
'MAX(paid_amount)',
'paid_currency',
'MAX(effective_from)',
'MAX(effective_to)'
))
->from($db->quoteName('rpo_organization_equity_entries'))
->where($db->quoteName('organization_id') . ' = '. $db->quote($rpo_id))
->group('`organization_ID`, `effective_from`, `Effective_to`') //this is the one
->order(($db->quoteName('effective_to') . ' IS NOT NULL'), $db->quoteName('effective_to') . ' DESC ');
$db->setQuery($query_rpo_organization_equity_entries);
$query_rpo_organization_equity_entries = $db->loadObjectList();
我没有对此进行过测试,但有些内容应该可行。