Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Allgemeiner SQL-Syntax für Multi-DBMS Projekt (https://www.delphipraxis.net/114163-allgemeiner-sql-syntax-fuer-multi-dbms-projekt.html)

klaus.meyer 20. Mai 2008 20:53

Datenbank: MySQL • Version: 5.0.51a • Zugriff über: PHP Wrapper-Klasse mit mysql_connect() ...

Allgemeiner SQL-Syntax für Multi-DBMS Projekt
 
Hallo liebe DP-ler,

ich bin gerade dabei mein CMS von Grund auf neu zu Programmieren und möchte jetzt die SQL Abfragen so allgemein wie möglich halten, damit ich durch austauschen der DB-Klasse andere Datenbank-Syteme wie PostgreSQL oder MSSQL verwenden kann.

Beispiel MySQL-Abfrage

SQL-Code:
SELECT `user_id` FROM `user` WHERE `user_id` < 42 ORDER BY `order`;
Wie könnte ich diese Abfrage so allgemein wie möglich halten? In MySQL sind ja ` die Seperatoren für Spaltennamen, in MSSQL wiederung [ und ] und in PostgreSQL glaube ich ".

Gibt es da nichts einheitliches? Ich möchte ungern die Querys doppelt im Sourcecode haben.

Mfg Klaus

mkinzler 20. Mai 2008 20:55

Re: Allgemeiner SQL-Syntax für Multi-DBMS Projekt
 
Für PHP gibt es schon einige Wrapper: MDB2, PDO, ADODB, ...

Elvis 20. Mai 2008 21:10

Re: Allgemeiner SQL-Syntax für Multi-DBMS Projekt
 
Bezeichner in Quotes sind doch nur nötig, wenn du ein keyword nutzt, oder der Name gegen die Regeln von Bezeichnern verstößt.

IOW: Du musst gar nichts in Single/Doublequotes, oder MSSQLs komische Klammern.
Ich habe absolut gar keinen Schimmer, warum mySQL-Opfer ständig diese Quotes setzen...


Edit2: Oh sorry, du musst ja PHP nutzen...

klaus.meyer 20. Mai 2008 21:26

Re: Allgemeiner SQL-Syntax für Multi-DBMS Projekt
 
Klammern will ich setzten wg. Keywords. (Habe auch gar keinen Einfluss auf die Feldnamen)
Die Wrapper von PHP sind dann quasi ne Schnittstelle, die ich mit allgemeiner Syntax ansprechen kann?

mkinzler 20. Mai 2008 21:29

Re: Allgemeiner SQL-Syntax für Multi-DBMS Projekt
 
Jein. Im gewissen Umfang

Elvis 20. Mai 2008 21:42

Re: Allgemeiner SQL-Syntax für Multi-DBMS Projekt
 
Zitat:

Zitat von klaus.meyer
Habe auch gar keinen Einfluss auf die Feldnamen

Doch hast du.
Der User kann anscheinend über dein System eigene Tabellen kreieren?
Dann sind deine SQLs doch eh dynamisch (du hast ja alle Metadaten bei der Hand) und wenn du die SQLs zusammenbaust, nutzt du halt die entsprechenden Quotes.

Ich habe keinen Plan von den Zugriffslibs von PHP (glücklicherweise ;-) ), kann dir also nicht sagen, ob adodb alleine die Quotes übersetzt.

joachimd 21. Mai 2008 10:09

Re: Allgemeiner SQL-Syntax für Multi-DBMS Projekt
 
Zitat:

Zitat von klaus.meyer
Hallo liebe DP-ler,

ich bin gerade dabei mein CMS von Grund auf neu zu Programmieren und möchte jetzt die SQL Abfragen so allgemein wie möglich halten, damit ich durch austauschen der DB-Klasse andere Datenbank-Syteme wie PostgreSQL oder MSSQL verwenden kann.

Ein guter Rat: lass es bleiben :-D
Nein, im Ernst: Schreibe Dir lieber eine Klassenbibliothek, welche Dir die Objekte so liefert, wie Du sie weiterverarbeiten kannst. Dann ersetzt Du die Klassenbibliothek für die einzelnen DBMS (zB um bei der Delphi-Syntax zu bleiben: TUser - abstract, TMySQLUser, TMSSQLUser, TPGUser usw).
Grund? Es gibt nichts wirklich einheitliches, die SQL Syntax unterscheidet sich, wenn auch nur minimal. Und denke mal über SQL Injection nach: Du musst Parameter verwenden, damit Dir das nicht passiert und das Parameter-Handling von MySQL ist mehr als umständlich.

alzaimar 21. Mai 2008 10:36

Re: Allgemeiner SQL-Syntax für Multi-DBMS Projekt
 
Zitat:

Zitat von joachimd
Grund? Es gibt nichts wirklich einheitliches,

Doch! "SELECT 1" funktioniert überall :mrgreen:

Dax 21. Mai 2008 11:28

Re: Allgemeiner SQL-Syntax für Multi-DBMS Projekt
 
Zitat:

Zitat von alzaimar
Zitat:

Zitat von joachimd
Grund? Es gibt nichts wirklich einheitliches,

Doch! "SELECT 1" funktioniert überall :mrgreen:

Nope, ältere PG-Versionen brauchen eine FROM-Klausel mit einer beliebigen Tabelle.

mikhal 21. Mai 2008 11:51

Re: Allgemeiner SQL-Syntax für Multi-DBMS Projekt
 
Oracle (9i) kann's auch nicht. Da verwendet man am besten "FROM DUAL"...

Grüße
Mikhal


Alle Zeitangaben in WEZ +1. Es ist jetzt 07:37 Uhr.
Seite 1 von 2  1 2      

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