AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi DBGrid sortieren mit unterschiedlichen DBMS Treibern
Thema durchsuchen
Ansicht
Themen-Optionen

DBGrid sortieren mit unterschiedlichen DBMS Treibern

Offene Frage von "Humbucker"
Ein Thema von Humbucker · begonnen am 5. Mär 2020 · letzter Beitrag vom 5. Mär 2020
Antwort Antwort
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#1

AW: DBGrid sortieren mit unterschiedlichen DBMS Treibern

  Alt 5. Mär 2020, 10:16
Ich würde bei bei den Treibern alle OLEDB Settings / Defaults vergleichen.
Jede DB Session "lebt" in dem Glauben bestimmte Locale Settings nutzen zu müssen. Die Herkunft dieser Vorgaben kann ganz unterschiedlich sein und am Ende je Tabellenspalte und definierter Locale verschieden.
MS erfindet ja gerne das Rad neu, aber vielleicht nicht so grundlegend. Meine Idee wären -dank MSO 365 Cloud- geänderte Standard Locale Settings...
Und ich würde nicht drauf wetten, aber diese OLEDB Treiber sind doch com server und da geschieht vermutlich das gleiche, wie mit anderen com servern, die Interfaces werden bei Neuinstallation jeweils durch den aktuellsten bedient. Bedeutet, die alten sind noch da, man muss sie "nur" gezielt über die Version ansprechen. Evtl. hilft dabei ein gezielter, programmatischer Aufbau der Connection.
Gruß, Jo
  Mit Zitat antworten Zitat
Humbucker

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

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
Angehängte Grafiken
Dateityp: png Image2.png (177,0 KB, 14x aufgerufen)
Dateityp: png Image1.png (178,2 KB, 17x aufgerufen)
Michael H.

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

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

AW: DBGrid sortieren mit unterschiedlichen DBMS Treibern

  Alt 5. Mär 2020, 11:13
Ich würde bei bei den Treibern alle OLEDB Settings / Defaults vergleichen.
Jede DB Session "lebt" in dem Glauben bestimmte Locale Settings nutzen zu müssen. Die Herkunft dieser Vorgaben kann ganz unterschiedlich sein und am Ende je Tabellenspalte und definierter Locale verschieden.
MS erfindet ja gerne das Rad neu, aber vielleicht nicht so grundlegend. Meine Idee wären -dank MSO 365 Cloud- geänderte Standard Locale Settings...
Und ich würde nicht drauf wetten, aber diese OLEDB Treiber sind doch com server und da geschieht vermutlich das gleiche, wie mit anderen com servern, die Interfaces werden bei Neuinstallation jeweils durch den aktuellsten bedient. Bedeutet, die alten sind noch da, man muss sie "nur" gezielt über die Version ansprechen. Evtl. hilft dabei ein gezielter, programmatischer Aufbau der Connection.
Habe ich gemacht und keine Unterschiede gefunden. In unserer Anwendung können die Treiber beim Start gewählt werden. In diesem Dialog stehen dann auch die Eigenschaften der Treiber zur Verfügung (die dann in den ConnectionString einfließen und an TADOConnection weitergegeben werden), so dass diese recht einfach verglichen werden können. Das Verhalten ist sogar provozierbar, indem nur der Treibername im Debug geändert wird (aus 12.0 mach 16.0), so dass alle anderen Eigenschaften identisch bleiben sollten.

Bezüglich des gezielten Ansprechens des Treibers ist zu sagen, dass genau das der Login Dialog macht. Es wird gezielt ein Treiber angesprochen und konfiguriert, der dann übergeben wird. Das Problem ist das Updateverhalten von Office 365, dass den korrekt und konkret angesprochenen Treiber verändert.
Michael H.
  Mit Zitat antworten Zitat
Antwort Antwort

 

Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 08:55 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz