Einzelnen Beitrag anzeigen

Humbucker

Registriert seit: 8. Feb 2013
Ort: im Lahntal
28 Beiträge
 
Delphi 10.4 Sydney
 
#3

AW: DBGrid sortieren mit unterschiedlichen DBMS Treibern

  Alt 5. Mär 2020, 11:05
Hallo,

ich habe zwischenzeitlich neue Erkenntnisse zum Thema. Das Problem hängt mit der unterschiedlichen Interpretation des Treibers der SQL-Abfrage zusammen. Felder, die in der SQL-Abfrage mit 'as' erzeugt werden, werden unterschiedlich interpretiert. Im konkreten Kontext wird das Feld 'Sendungsnummer' in der SQL-Abfrage wie folgt erzeugt:
Code:
iif(ISNULL(A.SENDUNG),iif(A.Abrechnungstyp = 69 ,''Mehrere'', ''Keine''), S.SENDUNGSNUMMER) as Sendungsnummer
Hieraus erzeugt der Treiber Microsoft.ACE.OLEDB.12.0 (Access 2007 Database Engine) den Feldtyp ftWideString (siehe Image1).

Hieraus erzeugt der Treiber Microsoft.ACE.OLEDB.16.0 (Access 2016 Database Engine) den Feldtyp ftWideMemo (siehe Image2) - und Memofelder können nicht sortiert werden

Da die Erzeugung von Feldern in einer SQL-Abfrage mit 'as' eine gängige Praxis in unserer Anwendung ist, kommt aufgrund der schieren Menge eine Umstellung per Cast nicht in Frage.

Gibt es eine Eigenschaft mit der dieses Verhalten der Treiber gesteuert werden kann? Vielleicht mit der ADOConnection? Oder mit dem Connection String der ADOConnetion?

Gruß Michael
Miniaturansicht angehängter Grafiken
image1.png   image2.png  
Michael H.

Geändert von Humbucker ( 5. Mär 2020 um 11:14 Uhr)
  Mit Zitat antworten Zitat