to_array() works. What we've done, is backwards ordering. The results returned by the query have the best one for each GroupID last, and while to_array traverses the results, it overwrites the keys and leaves us with only the desired result. This does mean however, that the SQL has to be done in a somewhat backwards fashion. Thats all you get for a disclaimer, just remember, this page isn't for the faint of heart. -A9 SQL template: SELECT CASE WHEN t.Format='MP3' AND t.Encoding='V0 (VBR)' THEN 1 WHEN t.Format='MP3' AND t.Encoding='V2 (VBR)' THEN 2 ELSE 100 END AS Rank, t.GroupID, t.Media, t.Format, t.Encoding, IF(t.Year=0,tg.Year,t.Year), tg.Name, a.Name, t.Size FROM torrents AS t INNER JOIN collages_torrents AS c ON t.GroupID=c.GroupID AND c.CollageID='8' INNER JOIN torrents_group AS tg ON tg.ID=t.GroupID AND tg.CategoryID='1' LEFT JOIN artists_group AS a ON a.ArtistID=tg.ArtistID LEFT JOIN torrents_files AS f ON t.ID=f.TorrentID ORDER BY t.GroupID ASC, Rank DESC, t.Seeders ASC */ if ( !isset($_REQUEST['collageid']) || !isset($_REQUEST['preference']) || !is_number($_REQUEST['preference']) || !is_number($_REQUEST['collageid']) || $_REQUEST['preference'] > 2 || count($_REQUEST['list']) == 0 ) { error(0); } if (!check_perms('zip_downloader')) { error(403); } $Preferences = array('RemasterTitle DESC', 'Seeders ASC', 'Size ASC'); $CollageID = $_REQUEST['collageid']; $Preference = $Preferences[$_REQUEST['preference']]; $DB->query("SELECT Name FROM collages WHERE ID='$CollageID'"); list($CollageName) = $DB->next_record(MYSQLI_NUM, false); $SQL = "SELECT CASE "; foreach ($_REQUEST['list'] as $Priority => $Selection) { if (!is_number($Priority)) { continue; } $SQL .= "WHEN "; switch ($Selection) { case '00': $SQL .= "t.Format='MP3' AND t.Encoding='V0 (VBR)'"; break; case '01': $SQL .= "t.Format='MP3' AND t.Encoding='APX (VBR)'"; break; case '02': $SQL .= "t.Format='MP3' AND t.Encoding='256 (VBR)'"; break; case '03': $SQL .= "t.Format='MP3' AND t.Encoding='V1 (VBR)'"; break; case '10': $SQL .= "t.Format='MP3' AND t.Encoding='224 (VBR)'"; break; case '11': $SQL .= "t.Format='MP3' AND t.Encoding='V2 (VBR)'"; break; case '12': $SQL .= "t.Format='MP3' AND t.Encoding='APS (VBR)'"; break; case '13': $SQL .= "t.Format='MP3' AND t.Encoding='192 (VBR)'"; break; case '20': $SQL .= "t.Format='MP3' AND t.Encoding='320'"; break; case '21': $SQL .= "t.Format='MP3' AND t.Encoding='256'"; break; case '22': $SQL .= "t.Format='MP3' AND t.Encoding='224'"; break; case '23': $SQL .= "t.Format='MP3' AND t.Encoding='192'"; break; case '30': $SQL .= "t.Format='FLAC' AND t.Encoding='24bit Lossless' AND t.Media='Vinyl'"; break; case '31': $SQL .= "t.Format='FLAC' AND t.Encoding='24bit Lossless' AND t.Media='DVD'"; break; case '32': $SQL .= "t.Format='FLAC' AND t.Encoding='24bit Lossless' AND t.Media='SACD'"; break; case '33': $SQL .= "t.Format='FLAC' AND t.Encoding='24bit Lossless' AND t.Media='WEB'"; break; case '34': $SQL .= "t.Format='FLAC' AND t.Encoding='Lossless' AND HasLog='1' AND LogScore='100' AND HasCue='1'"; break; case '35': $SQL .= "t.Format='FLAC' AND t.Encoding='Lossless' AND HasLog='1' AND LogScore='100'"; break; case '36': $SQL .= "t.Format='FLAC' AND t.Encoding='Lossless' AND HasLog='1'"; break; case '37': $SQL .= "t.Format='FLAC' AND t.Encoding='Lossless'"; break; case '40': $SQL .= "t.Format='DTS'"; break; case '42': $SQL .= "t.Format='AAC' AND t.Encoding='320'"; break; case '43': $SQL .= "t.Format='AAC' AND t.Encoding='256'"; break; case '44': $SQL .= "t.Format='AAC' AND t.Encoding='q5.5'"; break; case '45': $SQL .= "t.Format='AAC' AND t.Encoding='q5'"; break; case '46': $SQL .= "t.Format='AAC' AND t.Encoding='192'"; break; default: error(0); } $SQL .= " THEN $Priority "; } $SQL .= "ELSE 100 END AS Rank, t.GroupID, t.ID AS TorrentID, t.Media, t.Format, t.Encoding, IF(t.RemasterYear=0,tg.Year,t.RemasterYear) AS Year, tg.Name, t.Size FROM torrents AS t INNER JOIN collages_torrents AS c ON t.GroupID=c.GroupID AND c.CollageID='$CollageID' INNER JOIN torrents_group AS tg ON tg.ID=t.GroupID AND tg.CategoryID='1' ORDER BY t.GroupID ASC, Rank DESC, t.$Preference"; $DownloadsQ = $DB->query($SQL); $Collector = new TorrentsDL($DownloadsQ, $CollageName); while (list($Downloads, $GroupIDs) = $Collector->get_downloads('GroupID')) { $Artists = Artists::get_artists($GroupIDs); $TorrentFilesQ = $DB->query("SELECT TorrentID, File FROM torrents_files WHERE TorrentID IN (".implode(',', array_keys($GroupIDs)).")", false); if (is_int($TorrentFilesQ)) { // Query failed. Let's not create a broken zip archive foreach ($GroupIDs as $GroupID) { $Download =& $Downloads[$GroupID]; $Download['Artist'] = Artists::display_artists($Artists[$GroupID], false, true, false); $Collector->fail_file($Download); } continue; } while (list($TorrentID, $TorrentFile) = $DB->next_record(MYSQLI_NUM, false)) { $GroupID = $GroupIDs[$TorrentID]; $Download =& $Downloads[$GroupID]; $Download['Artist'] = Artists::display_artists($Artists[$Download['GroupID']], false, true, false); if ($Download['Rank'] == 100) { $Collector->skip_file($Download); continue; } $Collector->add_file($TorrentFile, $Download); unset($Download); } } $Collector->finalize(); $Settings = array(implode(':', $_REQUEST['list']), $_REQUEST['preference']); if (!isset($LoggedUser['Collector']) || $LoggedUser['Collector'] != $Settings) { Users::update_site_options($LoggedUser['ID'], array('Collector' => $Settings)); } define('IE_WORKAROUND_NO_CACHE_HEADERS', 1); ?>