AGB  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Umstellung InterBase 7.5 -> Firebird 2.5

Umstellung InterBase 7.5 -> Firebird 2.5

Ein Thema von mjustin · begonnen am 19. Jun 2017 · letzter Beitrag vom 20. Jun 2017
Antwort Antwort
mjustin

Registriert seit: 14. Apr 2008
2.408 Beiträge
 
Delphi 2009 Professional
 
#1

Umstellung InterBase 7.5 -> Firebird 2.5

  Alt 19. Jun 2017, 10:30
Datenbank: Firebird • Version: 2.5 • Zugriff über: gbak
Hallo,

eine InterBase Datenbank 7.5 (ODS 11.2) kann in Firebird 2.5 nicht geöffnet werden, ODS 11.2 in Firebird ist offensichtlich nicht kompatibel:

Code:
unsupported on-disk structure for file C:\I4\DB\TS2-RESTORED-1.GDB; found 11.2, support 11.2.
Beim Versuch, ein InterBase Backup einzulesen kommt man etwas weiter, allerdings bricht das Restore ab

Zitat:
C:\Windows\system32>"C:\Program Files\Firebird\Firebird_2_5\bin\gbak" -user SYSD
BA -password masterkey -r c:\i4\db\i4-d.gbk c:\i4\db\d.gdb -FIX_FSS_METADATA Win
1252 -FIX_FSS_DATA Win1252
...
gbak:do not recognize table attribute 18 -- continuing
gbak:do not recognize table attribute 18 -- continuing
gbak:do not recognize table attribute 18 -- continuing
gbak:do not recognize table attribute 18 -- continuing
gbak:do not recognize table attribute 18 -- continuing
gbak:do not recognize table attribute 18 -- continuing
gbak: ERROR:string truncated
gbak:Exiting before completion due to errors
Die Datenbank validiert in InterBase ohne Fehler.

Ist es über gbak "im Prinzip" möglich eine InterBase 7.5 Datenbank zu restoren oder setze ich gerade auf das falsche Pferd?
Michael Justin
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
38.077 Beiträge
 
Delphi 10 Seattle Professional
 
#2

AW: Umstellung InterBase 7.5 -> Firebird 2.5

  Alt 19. Jun 2017, 13:21
Lasse Dir ein SQL-Skript erstellen, dann sollte es funktionieren. DIE ODS-Versionen sind nicht kompatibel, deshalb funktioniert auch eine Backup/Restore nicht.
Markus Kinzler
  Mit Zitat antworten Zitat
mjustin

Registriert seit: 14. Apr 2008
2.408 Beiträge
 
Delphi 2009 Professional
 
#3

AW: Umstellung InterBase 7.5 -> Firebird 2.5

  Alt 19. Jun 2017, 14:07
Lasse Dir ein SQL-Skript erstellen, dann sollte es funktionieren. DIE ODS-Versionen sind nicht kompatibel, deshalb funktioniert auch eine Backup/Restore nicht.
Das SQL Skript (erstellt mit IBExpert) lässt sich leider nicht importieren.

Ein Beispiel: die maximale Länge der Generatornamen ist in Firebird kürzer:

Zitat:
BLR syntax error. Identifier GEN_KLR_KOSTENBUCHUNG_BEMERKUNG... is too long
-Name longer than database column size
Das gesamte Fehlerprotokoll mit 7000 Zeilen will ich hier nicht anhängen.


Viele der Fehlermeldungen sind leicht in der InterBase Datenbank korrigierbar. Ein großer Teil entfällt auf das Keyword DESCRIBE (Descriptions der Metadaten-Objekte). Das kann man allerdings in IBExpert über eine Option anpassen, dann werden COMMENT Statements im SQL Skript erzeugt.

Andere sind noch unklar (z.B. Fehlemeldungen die sich auf eine "ORDER BY" clause beziehen, die aber im SQL Statement der Stored Prozedure gar nicht enthalten ist:

Zitat:
Invalid expression in the ORDER BY clause (not contained in either an aggregate function or the GROUP BY clause)
Weitere Recherchen folgen
Michael Justin

Geändert von mjustin (19. Jun 2017 um 14:31 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von mikhal
mikhal

Registriert seit: 11. Sep 2003
Ort: Linz am Rhein
747 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#4

AW: Umstellung InterBase 7.5 -> Firebird 2.5

  Alt 19. Jun 2017, 15:05
Schau mal, ob dir die Data Pump von EMS weiterhilft...

Kostet zwar Geld, aber es gibt eine Testversion, die trotz ihrer Einschränkungen zumindest für einen Test hinreichend sein sollte!

Grüße
Mikhal
Michael Kraemer
Computer erleichtern die Arbeit...
...und die Erde ist eine Scheibe!
  Mit Zitat antworten Zitat
hanvas

Registriert seit: 28. Okt 2010
99 Beiträge
 
#5

AW: Umstellung InterBase 7.5 -> Firebird 2.5

  Alt 19. Jun 2017, 16:52

Das SQL Skript (erstellt mit IBExpert) lässt sich leider nicht importieren.
Ein Beispiel: die maximale Länge der Generatornamen ist in Firebird kürzer:
Nicht nur die Generatornamen. Die wesentlichen Einschränkungen IB 7.5->FB2.5 dürften sein :

Objektnamen dürfen bei Firebird 2.5 nicht länger als 31 Zeichen sein.
Spalten mit boolschen Werten werden nicht unterstützt.

Dementsprechend erst alle Objektnamen auf 31 Zeichen kürzen und boolsche Spalten durch andere Domain / Werte ersetzen. Welche Objekte Namen haben die länger als 31 Zeichen sind kann man durch Zugriff auf die Systemtabellen erfragen (http://docwiki.embarcadero.com/Inter.../System_Tables).

Ich würde dafür ein kleines Programm basteln das eine Liste mit Objektnamen > 31 Zeichen erstellt und für jeden Namen eine Ersetzung mit weniger als 31 Zeichen bastelt. Anschließend könntest Du anhand dieser Liste das SQL Script so bearbeiten das jedes Vorkommen mit mehr als 31 Zeichen durch den neuen Namen ersetzt wird.

Es müsste (bei entsprechenden Rechten) auch möglich sein die Objektnamen direkt in den Systemtabellen zu ändern, über die Nebenwirkungen kann ich nichts sagen.

cu Ha-Jö
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
5.772 Beiträge
 
Delphi XE4 Professional
 
#6

AW: Umstellung InterBase 7.5 -> Firebird 2.5

  Alt 19. Jun 2017, 18:35
Hallo,
Zitat:
Name longer than database column size
Vielleicht mit höherer PageSize restoren?

aus dem Kopf
gbak -page_size 16384
Heiko
  Mit Zitat antworten Zitat
hstreicher

Registriert seit: 21. Nov 2009
152 Beiträge
 
Delphi 10 Seattle Professional
 
#7

AW: Umstellung InterBase 7.5 -> Firebird 2.5

  Alt 19. Jun 2017, 20:01
Nein , das Limit ist "Hardcoded"

https://stackoverflow.com/questions/...le-name-length

es gibt Pläne das in V4 zu erhöhen

mfg Hannes
  Mit Zitat antworten Zitat
mjustin

Registriert seit: 14. Apr 2008
2.408 Beiträge
 
Delphi 2009 Professional
 
#8

AW: Umstellung InterBase 7.5 -> Firebird 2.5

  Alt 20. Jun 2017, 11:25
Danke für die vielen Antworten und Tipps!

Insgesamt ist der Versuch der Portierung eine empfehlenswerte Erfahrung, einige Probleme in den Metadaten werden von Firebird beim Einlesen des SQL Skripts erkannt, zum Beispiel

* uneindeutige Felder (ohne Alias)
* order by nach einem Feld das nicht in der Datenmenge vorkommt ("SELECT MIN(FELD) FROM TABELLE ORDER BY ANDERES_FELD"). InterBase akzeptiert dies, Firebird nicht. Es war in einer Stored Procedure tatsächlich damit ein Performancegewinn erreicht worden (anderer PLAN).

Die überlangen Generatornamen lassen sich, da es nur wenige sind, noch mit vertretbarem Aufwand ändern.
Michael Justin
  Mit Zitat antworten Zitat
mjustin

Registriert seit: 14. Apr 2008
2.408 Beiträge
 
Delphi 2009 Professional
 
#9

AW: Umstellung InterBase 7.5 -> Firebird 2.5

  Alt 20. Jun 2017, 13:21
Für Abfragen für Metadaten mit Namen länger ab 31 Zeichen konnte ich die substr UDF verwenden:

Zitat:
select rdb$constraint_name, substr(rdb$constraint_name, 31, 31), rdb$const_name_uq
from rdb$ref_constraints
where substr(rdb$constraint_name, 31, 31) <> ' '

select rdb$index_name, substr(rdb$index_name, 31, 31)
from rdb$indices
where substr(rdb$index_name, 31, 31) <> ' '

select rdb$trigger_name, substr(rdb$trigger_name, 31, 31)
from rdb$triggers
where substr(rdb$trigger_name, 31, 31) <> ' '
Constraints können direkt umbenannt werden, Indexdateien sowie Trigger werden gelöscht und neu angelegt.
Michael Justin
  Mit Zitat antworten Zitat
Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

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:

Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 02:43 Uhr.
Powered by vBulletin® Copyright ©2000 - 2017, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2017 by Daniel R. Wolf