Delphi-PRAXiS
Seite 3 von 3     123   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   MySQL versus MsSQL Syntax Group By (https://www.delphipraxis.net/207879-mysql-versus-mssql-syntax-group.html)

himitsu 14. Mai 2021 22:07

AW: MySQL versus MsSQL Syntax Group By
 
Egal ob AutoFetch/FetchAll/... oder nicht,
sollte doch dennoch RecordCount mit der Gesamtzahl von der DB übereinstimmen? (fast alle anderen DBComponentenHersteller bekommen das ja auch hin)

jobo 14. Mai 2021 22:55

AW: MySQL versus MsSQL Syntax Group By
 
Zitat:

Zitat von Redeemer (Beitrag 1489479)
Ja, es ist etwas unlogisch, dass wenn du ein JOIN-Kriterium ein PK ist und trotzdem man alle Felder aggregieren oder gruppieren muss. Aber es ist konsequent bzgl. der Regel dass jedes Feld aggregiert oder gruppiert ist.

Die Fehlermeldung im ersten Post ist ziemlich exakt, wenn man ihr folgt und das bemeckerte Feld in die Group By Clause schreibt, wird die nächste kommen. Man folgt also der Fehlermeldung so lange, bis nicht mehr gemeckert wird und das DB System in der Lage ist, die Abfrage richtig zu "verstehen". Dann erhält man korrekte Daten. (analog kann man das Spielchen machen und die bemeckerten Felder aggregieren)

Es gibt DB Systeme, die anhand von Schlüsselfeldinformationen und sagen wir mal lazy geschriebenen Group By Clauses trotzdem richtig arbeiten. Das ist ein Feature, die Systeme haben das dokumentiert.

By mySQL ist es leider nicht so, zumindest nicht im 0815 frisch installiert Modus. Es glaubt nur, es könnte auch mit mangelhaften Group By Anweisungen eindeutig richtige Annahmen zur notwendigen Gruppierung treffen, es vertut sich aber manchmal. Und wann es das macht, ist nicht transparent. An der Stelle gibt es keine Fehlermeldung. Man bekommt einfach falsche Daten.

Es ist schon ein gehöriger Unterschied, ob man eine Fehlermeldung wegen einer falschen/(unsauber kennt das System nicht) bekommt oder falsche Daten wegen falscher Interpretation der Abfrage.

Uwe Raabe 14. Mai 2021 22:56

AW: MySQL versus MsSQL Syntax Group By
 
Zitat:

Zitat von himitsu (Beitrag 1489481)
Egal ob AutoFetch/FetchAll/... oder nicht,
sollte doch dennoch RecordCount mit der Gesamtzahl von der DB übereinstimmen? (fast alle anderen DBComponentenHersteller bekommen das ja auch hin)

Muss man halt nur entsprechend einstellen: RecordCountMode

Delphi-Quellcode:
Query.FetchOptions.RecordCountMode := cmTotal;


Alle Zeitangaben in WEZ +1. Es ist jetzt 08:54 Uhr.
Seite 3 von 3     123   

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz