AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi [Firebird] Datensätze in Backup-DB verschieben/spiegeln
Thema durchsuchen
Ansicht
Themen-Optionen

[Firebird] Datensätze in Backup-DB verschieben/spiegeln

Ein Thema von messie · begonnen am 5. Okt 2014 · letzter Beitrag vom 6. Okt 2014
Antwort Antwort
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.879 Beiträge
 
Delphi 11 Alexandria
 
#1

AW: [Firebird] Datensätze in Backup-DB verschieben/spiegeln

  Alt 5. Okt 2014, 17:25
Die Größe einer Datenbank hat nicht unbedingt etwas mit der Performance zu tun.

Zitat:
Wenn ich das mit INSERT mache, bekomme ich für jedes Datum einen neuen Index. Das ist zu Fuß recht umständlich.
Meint Du eine neue ID. Das kommt auf das Insertstatement an bzw. den Trigger

Insert .. SELECT funktioniert m.W. nicht bei Crossdatenbank-Abfragen, würde aber gehen, wenn du diese nur in eine andere Tabelle verschieben willst.
Markus Kinzler

Geändert von mkinzler ( 5. Okt 2014 um 17:27 Uhr)
  Mit Zitat antworten Zitat
messie

Registriert seit: 2. Mär 2005
Ort: Göttingen
1.592 Beiträge
 
Delphi 2009 Professional
 
#2

AW: [Firebird] Datensätze in Backup-DB verschieben/spiegeln

  Alt 5. Okt 2014, 17:57
Die Größe einer Datenbank hat nicht unbedingt etwas mit der Performance zu tun.

Zitat:
Wenn ich das mit INSERT mache, bekomme ich für jedes Datum einen neuen Index. Das ist zu Fuß recht umständlich.
Meint Du eine neue ID. Das kommt auf das Insertstatement an bzw. den Trigger

Insert .. SELECT funktioniert m.W. nicht bei Crossdatenbank-Abfragen, würde aber gehen, wenn du diese nur in eine andere Tabelle verschieben willst.
Hallo Markus,

ja, ich meinte die neue ID. Die Backup-DB würde ich identisch mit der Original-DB aufbauen, also auch mit den Triggern.

Verstehe ich das richtig, dass dort ein Konstrukt
Code:
INSERT INTO <BackupDB1,BackupDB2,BackupDB3,...>
select <große Query die alle Datensätze zu einem Auftrag lädt>
reichen würde? Bekomme ich dann neue IDs?
Denn ich würde evtl. auch eine Abfrage einbauen wollen, die nach einer vorhandenen Auftrags-ID bzw. den IDs in den anderenTabellen sucht.


Grüße, Messie
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.879 Beiträge
 
Delphi 11 Alexandria
 
#3

AW: [Firebird] Datensätze in Backup-DB verschieben/spiegeln

  Alt 5. Okt 2014, 18:06
Es kann nur eine Zieltabelle geben, diese kann mit der Quelltabelle übereinstimmen. Die Feldliste muss identisch sei (Anzahl/Reihenfolge der Typen)
Insert into <Ziel-Tabelle>(<Feldliste>) select <Feldliste> from <Quell-Tabelle>; Ob neue IDs vergeben werden hängt vom Trigger ab, wirkt er nur bei leerem PK Feld, dann werden die originären Ids verwendet; vergibt der Trigger aber grundsätzlich neue Werte dann nicht. In diesem Fall müsstest Du die Trigger vorher deaktiviren.
Markus Kinzler
  Mit Zitat antworten Zitat
messie

Registriert seit: 2. Mär 2005
Ort: Göttingen
1.592 Beiträge
 
Delphi 2009 Professional
 
#4

AW: [Firebird] Datensätze in Backup-DB verschieben/spiegeln

  Alt 5. Okt 2014, 18:19
Es kann nur eine Zieltabelle geben, diese kann mit der Quelltabelle übereinstimmen. Die Feldliste muss identisch sei (Anzahl/Reihenfolge der Typen)
Hallo Markus,

mir fehlt noch ein kleiner Baustein: Wie rufe ich zwei identische Tabellen in unterschiedlichen DB auf? Gibt es etwas wie Datenbank1.Tabelle1 und Datenbank2.Tabelle1?

Grüße, Messie
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.879 Beiträge
 
Delphi 11 Alexandria
 
#5

AW: [Firebird] Datensätze in Backup-DB verschieben/spiegeln

  Alt 5. Okt 2014, 18:28
So einfach nicht, deshalb riet ich ja zu Tabellen statt Datenbanken. Seit FB 2.5 gibt es die Möglichkeit in PSQL Afragen auf andere Datenbanken abzusetzen; die möglichkeiten sind aber noch sehr bschränkt, es sind keine Joins o.ä. möglich, aber datenbankübergreifende Transaktionen.

SQL-Code:
execute block returns (<Felder von externer Datenbanktabelle>) as
begin
FOR EXECUTE STATEMENT 'select <Felder von externer Datenbanktabelle> from <externer Datenbanktabelle>'
ON EXTERNAL DATA SOURCE '<Host>:<externe Datenbank>AS USER 'sysdba' PASSWORD 'masterkey'
INTO <Paramterliste>
DO SUSPEND;
end;
Markus Kinzler
  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 20:27 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