Okay, hier ist die Situation, ich habe eine Anwendung in Zend_Framework geschrieben, die sowohl mit MySQL als auch mit MSSQL als Backend kompatibel ist. Nun, ZF ist ziemlich gut darin, viele der SQL-Diskrepanzen/Unterschiede zwischen den beiden Sprachen zu lösen, aber ich muss diese noch herausfinden.Zend_Db_Auswahl nach dem Zufallsprinzip, kompatibel in mssql/mysql
Ziel ist es, einen zufälligen Datensatz aus der Tabelle auszuwählen, was eine äußerst einfache Aussage ist.
Hier ist eine select-Anweisung zum Beispiel:
$sql = $db->select()
->from("table")
->order("rand()")
->limit(1);
Diese perfekt für die MySQL-Datenbank-Tabellen funktioniert, weil die SQL für MySQL ist wie folgt:
SELECT `table`.* FROM `table` ORDER BY rand() ASC
Jetzt MSSQL auf der anderen Seite, verwendet die Funktion newid(), um eine Randomisierung durchzuführen.
Gibt es eine Art von Helfer, den ich in die order() Funktion übergeben kann, um es zu erkennen, dass es die richtige Reihenfolge verwenden muss? Ich habe die Dokumentation und die Zfforums durchsucht, ein paar Tipps gefunden, aber nichts Solides.
Eines der Dinge, die ich finden tat, war:
ORDER BY RANDOM() not working - ZFForums.com
Sie verwenden die folgenden:
$res = $db->fetchAll(
'SELECT * FROM table ORDER BY :random',
array('random' => new Zend_Db_Expr('RANDOM()')
);
Es funktioniert ... aber ich bin nicht auf der Suche nach baue meine select-Anweisung auf, indem ich sie austippe und eine Ersetzung für die Zeichenfolge durchführe. Ich versuche, sie im selben Zend_Db_Select-Objekt zu behalten. Ich habe auch versucht, die Zend_Db_Expr('RANDOM()')
in die ->order()
auf der Anweisung zu übergeben, und es schlägt fehl. Er postuliert auch eine theoretische Lösung, um die Antwort zu finden, aber ich versuche nicht, die Funktion, in der sie sich befindet, neu zu schreiben, indem ich den Aufruf von $ db-> fetch() modifiziere.
Irgendwelche Ideen?
Ich mag es, aber ich denke, ich mag gnarf Idee ein bisschen mehr. Es reicht aus, den Table Abstract für eine zufällige Auswahl zu erweitern. – Jesta
Ja, natürlich. Meine Lösung ist komplexer und kommt von der Sache, die Sie erstellen möchten ** EIN EXPRESSION ** basierend auf einem Adapter. Daher ist es im Allgemeinen für jedes andere Projekt wiederverwendbar ... Aber ich stimme zu, dass die Tabellenlösung einfacher ist ... –
Am Ende zeigte er auch das Db_Expr, das Sie für MSSQL und MySQL verwenden können, ohne es modifizieren zu müssen in der Regel auch für jedes Projekt wiederverwendbar. – Jesta