Delphi-PRAXiS
Seite 1 von 3  1 23      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   DB-Funktionen von MSSQL in Oracle nachbauen (https://www.delphipraxis.net/204290-db-funktionen-von-mssql-oracle-nachbauen.html)

Jumpy 15. Mai 2020 14:53

Datenbank: Oracle • Version: 11g • Zugriff über: versch.

DB-Funktionen von MSSQL in Oracle nachbauen
 
Hallo,

wir haben ein Fremd-Programm, dass mit verschieden DBMS zusammenarbeiten kann übernommen und dabei von MSSQL nach Oracle migriert. Läuft soweit alles.
Der Kunde setzt nun aber zu Auswertungs-Zwecken tausende (keine Übertreibung!) selbstgebastelte SQL-Statements ein und in diesen finden sich dann auch klassische SQL-Funktionen von MSSQL, ich sag mal als Beispiel die Funktion ISNULL.
Wir möchten jetzt vermeiden tausende SQL-Statements anzupacken und umschreiben zu müssen und würden gerne diese Funktionen in Oracle als eigene DB-Function nachbauen, also im Beispiel eine Function "ISNULL" schreiben, die dann intern mit Oracles "NVL" arbeitet.

Deswegen nun die Frage: Hat das vielleicht schon mal wer gemacht, gibt es da vllt. fertige Scripte um die gängigsten MSSQL-Function in Oracle nachzubauen.

mkinzler 15. Mai 2020 15:26

AW: DB-Funktionen von MSSQL in Oracle nachbauen
 
Vielleicht so ein Ansatz wie bei Fyracle. Also ein (Proxy-)Server, der die Abfragen umwandelt und die angepassten Abfragen dann an das eigentliche DBMS weiterleitet.

http://sqlrelay.sourceforge.net/documentation.html

Bernhard Geyer 15. Mai 2020 16:10

AW: DB-Funktionen von MSSQL in Oracle nachbauen
 
Zitat:

Zitat von Jumpy (Beitrag 1464653)
wir haben ein Fremd-Programm, dass mit verschieden DBMS zusammenarbeiten kann übernommen und dabei von MSSQL nach Oracle migriert. Läuft soweit alles.

Beileid. Aber wenn man meint das zu müssen ... (OK, war jetzt Off-Topic)

Zitat:

Zitat von Jumpy (Beitrag 1464653)
Der Kunde setzt nun aber zu Auswertungs-Zwecken tausende (keine Übertreibung!) selbstgebastelte SQL-Statements ein und in diesen finden sich dann auch klassische SQL-Funktionen von MSSQL, ich sag mal als Beispiel die Funktion ISNULL.

Also habt ihr doch nicht Migriert. War euch nicht im Vorfeld klar das genau sowas auch zu einer Migration gehört?

Zitat:

Zitat von Jumpy (Beitrag 1464653)
Wir möchten jetzt vermeiden tausende SQL-Statements anzupacken und umschreiben zu müssen und würden gerne diese Funktionen in Oracle als eigene DB-Function nachbauen, also im Beispiel eine Function "ISNULL" schreiben, die dann intern mit Oracles "NVL" arbeitet.

Habt ihr wirklich zu eine 13 Jahre alten Oracle-Version gewechselt? (Es steht Oracle 11 am Ticket)

Hintergrund: Auch Oracle kann nicht dem SQL-Standard sperren und mit neueren Versionen (z.B. 18 als Long-Support-Version) lösen sich evtl. einige der Probleme in Luft auf, da Oracle dann evtl. mehr 1:1 Gegenstück zu solchen MS SQL Server Funktionen hat.

p80286 17. Mai 2020 09:34

AW: DB-Funktionen von MSSQL in Oracle nachbauen
 
Wie wäre es mit einer Übersetzungssoftware replace(msstatement,oraclestatement)? Beide Systeme sind unterschiedlich, dann sind die Scripte es auch!
Hätte nebenher den Vorteil der Übersetzer wäre auch für andere Systemwechsel einsetzbar.

Gruß
K-H

Bernhard Geyer 17. Mai 2020 09:57

AW: DB-Funktionen von MSSQL in Oracle nachbauen
 
Zitat:

Zitat von Jumpy (Beitrag 1464653)
wir haben ein Fremd-Programm, dass mit verschieden DBMS zusammenarbeiten kann übernommen und dabei von MSSQL nach Oracle migriert. Läuft soweit alles.

Auch wenn es OT ist.
Wieso macht man sowas?
In unserem Umfeld migriert man eher von Oracle weg, als nach Oracle.
Hat in euren Umfeld Oracle einen Unschlagbaren Vorteil, welche (wegen der scripts) doch sehr aufwendigen und teure Migration rechtfertigen würde?

Jumpy 18. Mai 2020 09:35

AW: DB-Funktionen von MSSQL in Oracle nachbauen
 
Wir leben leider nicht auf der grünen Wiese.

Wir haben die Server und die Lizensen für Oracle und da auch ~20 Datenbanken für ~50 Kunden mit der Software am laufen. Die Umstellung auf Oracle ist auch normalerweise kein Problem und deswegen stellen wir darauf um, wenn der Kunde bisher selbstgehostet auf MSSQL unterwegs war und zu uns wechselt. Das geht auch rechtg problemlos, mit den Migration-Tools des Softwareherstellers.

Ist halt jetzt das erste mal, das ein Kunde sein eigenes Auswertungstool weiterhin mit seinen ganzen selbst gemachten Abfragen benutzen will und der Vertrieb, wie das nun mal so ist, gesagt hat, dass das natürlich weiterhin möglich sein wird :).

Zur alten Oracle Version für die noch ältere Software:
Die Oracle-Version wird von der Fremdsoftware vorgegeben 10i bis 12? ist derzeit supported und wird was man so hört nicht mehr neuer werden, da die mittlerweile auf PostgreSQL schielen. Wenn das mal soweit ist und stabil ist und wir uns das KnowHow angeeignet haben, werden wir da bestimmt mit gehen, allein schon aus Kostengründen.

DasWolf 18. Mai 2020 09:58

AW: DB-Funktionen von MSSQL in Oracle nachbauen
 
Zitat:

Zitat von Bernhard Geyer (Beitrag 1464656)
Hintergrund: Auch Oracle kann nicht dem SQL-Standard sperren und mit neueren Versionen (z.B. 18 als Long-Support-Version) lösen sich evtl. einige der Probleme in Luft auf, da Oracle dann evtl. mehr 1:1 Gegenstück zu solchen MS SQL Server Funktionen hat.

ISNULL ist nicht der SQL-Standard und wird in ORACLE auch keine Verwendung finden.
ISNULL ist SQL-Server spezifisch und NVL ist Oracle-spezifisch.

COALESCE ist der SQL-Standard und funktioniert bei beiden DBMS.

Bernhard Geyer 18. Mai 2020 10:45

AW: DB-Funktionen von MSSQL in Oracle nachbauen
 
Zitat:

Zitat von Jumpy (Beitrag 1464759)
Wir leben leider nicht auf der grünen Wiese.

Kenn ich :-)

Zitat:

Zitat von Jumpy (Beitrag 1464759)
Wir haben die Server und die Lizensen für Oracle und da auch ~20 Datenbanken für ~50 Kunden mit der Software am laufen.

Wir können eigentlich auch Problemlos zwischen diversen DBMS-Systemen zwitschen.
Man darf halt nicht vergessen zu Fragen bzw. darauf hinzuweisen das es nur diese SW-Teil betrifft und "Hingestrickte" eigene Abfrage in eigenregie umgestellt werden müssen.

Zitat:

Zitat von Jumpy (Beitrag 1464759)
... und der Vertrieb, wie das nun mal so ist, gesagt hat, dass das natürlich weiterhin möglich sein wird :).


Bernhard Geyer 18. Mai 2020 10:45

AW: DB-Funktionen von MSSQL in Oracle nachbauen
 
Zitat:

Zitat von DasWolf (Beitrag 1464762)
COALESCE ist der SQL-Standard und funktioniert bei beiden DBMS.

Coalesce war bei uns einer der Gründe das wir mit neueren Versionen der Anwendung definitiv kein alte Oracles mehr unterstützen, welche kein Coalesce können.

himitsu 18. Mai 2020 11:23

AW: DB-Funktionen von MSSQL in Oracle nachbauen
 
ISNULL als Funktion() oder als Operator?

Postgres kennt auch sowas (x IS NULL, x IS NOT NULL, x ISNULL und x NOTNULL),
aber der Operator ließe sich im SQL-Export/Backup ja problemlos String-Replacen,
anstatt unnötig aufwändig diese Funktionen nachzubauen.

"ISNULL(" -> "COALESCE("
"NOT ISNULL" -> "IS NOT NULL"
"NOTNULL" -> "IS NOT NULL"
"ISNULL" -> "IS NULL"

Oracle kann kein COALESCE?
Zitat:

COALESCE ist der SQL-Standard und funktioniert bei beiden DBMS
klang so, als wenn wenigstens das ging


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

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