Implizite Datentypkonvertierung
Eine implizite Datenkonvertierung ist in Dialekt 3 nicht möglich — die CAST
-Funktion wird fast immer benötigt, um Datentypkonflikte zu vermeiden.
In Dialekt 1 wird in vielen Ausdrücken ein Typ implizit in einen anderen umgewandelt, ohne dass die CAST-Funktion verwendet werden muss.Zum Beispiel gilt die folgende Aussage in Dialekt 1:
UPDATE ATABLE
SET ADATE = '25.12.2016' + 1
Das Datumsliteral wird implizit in den Datumstyp umgewandelt.
In Dialekt 3 wird diese Anweisung den Fehler 35544569 ausgeben, “`Dynamic SQL Error: expression evaluation not supported, Strings cannot be added or subtracted in dialect 3” — eine Umwandlung ist erforderlich:
UPDATE ATABLE
SET ADATE = CAST ('25.12.2016' AS DATE) + 1
Oder mit einem Datetime-Literal:
UPDATE ATABLE
SET ADATE = DATE '25.12.2016' + 1
In Dialekt 1 ist es normalerweise möglich, ganzzahlige Daten und numerische Zeichenfolgen zu mischen, da der Parser versucht, die Zeichenfolge implizit umzuwandeln.Beispielsweise,
2 + '1'
wird korrekt ausgeführt.
In Dialekt 3 führt ein solcher Ausdruck zu einem Fehler, daher müssen Sie ihn als CAST
-Ausdruck schreiben:
2 + CAST('1' AS SMALLINT)
Die Ausnahme von der Regel ist während der String-Verkettung.