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
Seite 1 von 2  1 2      
messie

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

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

  Alt 5. Okt 2014, 18:17
Datenbank: Firebird • Version: 2.5 • Zugriff über: IBDAC
Moin,

ich habe eine ständig wachsende Datenbank und möchte aus Geschwindigkeitsgründen Datensätze in eine Backup-DB verschieben. Wenn ich das mit INSERT mache, bekomme ich für jedes Datum einen neuen Index. Das ist zu Fuß recht umständlich.

Ist es möglich, Daten en bloque unter Beibehaltung der Indices in eine andere Datenbank mit identischer Struktur zu verschieben? Die nicht verschobenen Indices wären zunächst frei und würden dann gefüllt falls der entsprechende Datensatz auch verschoben wird.

Für ein paar Stichworte wäre ich sehr dankbar.

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

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

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

  Alt 5. Okt 2014, 18: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 18:27 Uhr)
  Mit Zitat antworten Zitat
messie

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

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

  Alt 5. Okt 2014, 18: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.858 Beiträge
 
Delphi 11 Alexandria
 
#4

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

  Alt 5. Okt 2014, 19: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
 
#5

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

  Alt 5. Okt 2014, 19: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.858 Beiträge
 
Delphi 11 Alexandria
 
#6

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

  Alt 5. Okt 2014, 19: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
Blup

Registriert seit: 7. Aug 2008
Ort: Brandenburg
1.465 Beiträge
 
Delphi 12 Athens
 
#7

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

  Alt 6. Okt 2014, 09:19
Wenn ich das mit INSERT mache, bekomme ich für jedes Datum einen neuen Index. Das ist zu Fuß recht umständlich.

Ist es möglich, Daten en bloque unter Beibehaltung der Indices in eine andere Datenbank mit identischer Struktur zu verschieben? Die nicht verschobenen Indices wären zunächst frei und würden dann gefüllt falls der entsprechende Datensatz auch verschoben wird.
Für mich hört sich das nach einer ungünstigen Datenstruktur an, nach dem Motto für jeden Tag eine neue Tabelle.
Normalerweise hat man nur eine Tabelle und die Datensätze haben eine Spalte Datum.
Dann braucht sich die Datenstruktur auch nicht jeden Tag zu ändern.

Zum Thema:
Eine 1:1 Kopie der aktuellen Datenbank erstellen (z.B. als Shadow erstellen und dann abkoppeln) und als Archiv ablegen.
In der aktuellen Datenbank alle nicht benötigten Daten löschen.
Mehr Aufwand lohnt sich nicht.
  Mit Zitat antworten Zitat
tsteinmaurer

Registriert seit: 8. Sep 2008
Ort: Linz, Österreich
530 Beiträge
 
#8

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

  Alt 6. Okt 2014, 09:47
Eine andere Möglichkeit wäre das Ganze asynchron über eine uni-direktionale Replikation zu machen. Zum Beispiel: http://www.iblogmanager.com/download...hotstandby.htm
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.079 Beiträge
 
Delphi 12 Athens
 
#9

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

  Alt 6. Okt 2014, 10:53
Wenn du die Daten unbedingt aufteilen willst, dann gäbe es auch noch die Partitionierung von Tabellen.


Spiegeln verändert doch erstmal nichts an der Performance.
Man kann da bei vielen Zugriffen die Zugriffe auf unterschiedliche DB-Server verteilen und hat dann in der Masse mehr Leistung.
Bzw. man hat immer ein aktuelles Backup.

Wobei Backup: Wenn man in der einen DB ausversehn etwas ändert/löscht, dann ist es in der anderen DB praktisch auch gleich weg.
Es wäre also nur ein hochaktuelles Backup zum Abfangen eines Serverausfalls, wo man auch gleich auf das andere System umschalten könnte.

PS:
http://entwickler-forum.de/archive/i...p/t-40590.html
http://www.delphipraxis.net/162657-e...tenbanken.html
http://www.ibexpert.net/ibe_de/index...ecommendations
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.

Geändert von himitsu ( 6. Okt 2014 um 11:06 Uhr)
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

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

  Alt 6. Okt 2014, 11:00
Zitat:
Wenn du die Daten unbedingt aufteilen willst, dann gäbe es auch noch die Partitionierung von Tabellen.
Das wird aber nicht von allen DBMS unterstützt, z.B. von dem es hier geht nicht.
Markus Kinzler
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 22:43 Uhr.
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