Mitunter möchte man ein Abfrageergebnis nach einer vorgegebenen Liste von IDs sortieren, also weder alphabetisch nach Namen, noch numerisch nach Wert, sondern auf Basis einer konfigurierten Reihenfolge von Werten. Da man in PostgreSQL auch Funktions-Ergebnisse als Argumente für eine Sortierung verwenden kann, können wir eine Hilfsfunktion in der Datenbank deklarieren, über die sich diese Form der Sortierung umsetzen lässt:

Jetzt können wir die Funktion zur Sortierung einsetzen:

Das NULLS LAST stellt sicher, dass Werte die nicht in der Liste enthalten sind ans Ende des Ergebnisses sortiert werden.

Bei sehr umfangreichen Datenmengen kann die direkte Nutzung eines Index für die Funktion sinnvoll sein. Die ist aufgrund der IMMUTABLE-Deklaration auch möglich, allerdings nur für eine spezifische Werteliste, die damit Teil der Index-Deklaration werden muss. Im Normalfall genügt allerdings ein Index auf das verwendete Feld selbst.

In ColdFusion kann auch an dieser Stelle <cfqueryparam> für die Sortierung eingesetzt werden. Wichtig ist dabei, dass hier der richtige Datentyp für die Liste gewählt wird – z.B. wenn die Spalte vom Typ int8/bigInt ist. Auch einfache int-Arrays (cf_sql_integer) oder Text-Arrays (cf_sql_varchar) sind natürlich möglich.

Schönes kleines WTF am späten Nachmittag:

BLAM!

Element STRUCTDATA.DEALIDS is undefined in LOCAL.
The error occurred in /var/www/.../some.cfc: line 120
118 : while( local.objCursor.hasNext() ){
119 : local.structData = local.objCursor.next();
120 : if (structKeyExists(local.structData,'dealIds') && isArray(local.structData.dealIds)) {

Weiterlesen

Nur weil’s gerade einen Kollegen mal wieder gebissen hat: ColdFusion and Pass by Reference versus Value

Kurzfassung: In CF (wie auch in Perl) werden defaultmäßig nur Primitive als Werte zugewiesen, alles andere nur als Referenz. Wenn man z.B. einen Loop baut und den Elementen eines Arrays eine Structure zuweist, kann das dazu führen, dass Werte in anderen Elementen überschrieben werden. Wenn man statt der Referenz also die Werte benötigt, ist duplicate() erforderlich.

Java dagegen nutzt immer pass by value, bei C++ und C# ist das ebenfalls der Default, wobei die mit dem ref-Keyword auch pass by reference unterstützen.

Diese subtile kleine Besonderheit ist immer wieder gut für schöne Brainfuck-Bugs 😉

Kurzes Snippet, um CORS in einer remote CFC-Methode zu erlauben:

Verwendung z.B. in jQuery