AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Firebird: Constraint enable/disable?
Thema durchsuchen
Ansicht
Themen-Optionen

Firebird: Constraint enable/disable?

Ein Thema von omata · begonnen am 30. Dez 2008 · letzter Beitrag vom 3. Mär 2010
Antwort Antwort
Seite 1 von 2  1 2      
omata

Registriert seit: 26. Aug 2004
Ort: Nebel auf Amrum
3.154 Beiträge
 
Delphi 7 Enterprise
 
#1

Firebird: Constraint enable/disable?

  Alt 30. Dez 2008, 22:26
Datenbank: Firebird • Version: 2.1 • Zugriff über: -
Gibt es eine Möglichkeit, in Firebird, Constraints abzuschalten? Ich möchte sie nicht löschen, sondern nur kurzzeitig außer Kraft setzen.

Hoffe ihr habt einen Tipp für mich.
  Mit Zitat antworten Zitat
Benutzerbild von Wunni
Wunni

Registriert seit: 1. Mai 2003
Ort: Hamburg
46 Beiträge
 
FreePascal / Lazarus
 
#2

Re: Firebird: Constraint enable/disable?

  Alt 30. Dez 2008, 22:38
alter index <Indexname> inactive;
Andreas Wunnenberg
  Mit Zitat antworten Zitat
omata

Registriert seit: 26. Aug 2004
Ort: Nebel auf Amrum
3.154 Beiträge
 
Delphi 7 Enterprise
 
#3

Re: Firebird: Constraint enable/disable?

  Alt 30. Dez 2008, 22:46
Hallo Wunni,

vielen Dank für deinen Hinweis.

Ich möchte aber keinen Index deaktivieren, sondern alle Foreign-Keys und den Primary-Key einer Tabelle.

Sorry, für die unpräzise Fragestellung.
  Mit Zitat antworten Zitat
Benutzerbild von Wunni
Wunni

Registriert seit: 1. Mai 2003
Ort: Hamburg
46 Beiträge
 
FreePascal / Lazarus
 
#4

Re: Firebird: Constraint enable/disable?

  Alt 30. Dez 2008, 22:54
Sorry, Deine Frage war schon klar formuliert. Ich habe mich von IBExpert täuschen lassen. Bei Interbase kann man den Foreign Key nicht deaktivieren. Man kann mit IBExpert aber bei einer Firebird 2.0 Datenbank den Foreign Key deaktivieren, erhält dann aber vom Firebird Server eine Exception.
Andreas Wunnenberg
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.270 Beiträge
 
Delphi 10.4 Sydney
 
#5

Re: Firebird: Constraint enable/disable?

  Alt 30. Dez 2008, 23:03
Hallo,

zuerst doch mal die Frage, wozu ?


Heiko
Heiko
  Mit Zitat antworten Zitat
omata

Registriert seit: 26. Aug 2004
Ort: Nebel auf Amrum
3.154 Beiträge
 
Delphi 7 Enterprise
 
#6

Re: Firebird: Constraint enable/disable?

  Alt 31. Dez 2008, 00:49
Hallo Heiko,

ich möchte zwei Datenbanken synchronisieren.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Firebird: Constraint enable/disable?

  Alt 31. Dez 2008, 10:28
Das geht m.W. nur wenn man die Datenbank in den singelusermodus versetzt
SQL-Code:
alter constraint <constraint> disable;
...
alter constraint <constraint> enable;
Markus Kinzler
  Mit Zitat antworten Zitat
omata

Registriert seit: 26. Aug 2004
Ort: Nebel auf Amrum
3.154 Beiträge
 
Delphi 7 Enterprise
 
#8

Re: Firebird: Constraint enable/disable?

  Alt 31. Dez 2008, 16:08
Ok, danke schonmal für diese Infos.

Man kann also einen Constraint ein-/abschalten. Geht das auch bezogen auf eine Tabelle? Oder muss ich mir jetzt erstmal alle Constraints einer Tabelle raussuchen, um sie dann abzuschalten?

Ich denke dabei an (mssql) folgendes...
Code:
ALTER TABLE tabelle NOCHECK CONSTRAINT ALL
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Firebird: Constraint enable/disable?

  Alt 31. Dez 2008, 16:17
Keine Ahnung im Zweifel einfach eine Schleife über alle Constraints ( über Systemtabllen). Oder Schreibe Holger (User IBexpert) oder Thomas ( Steinmaurer) mal per PN oder Email an.
Markus Kinzler
  Mit Zitat antworten Zitat
shadowman

Registriert seit: 1. Nov 2005
48 Beiträge
 
#10

Re: Firebird: Constraint enable/disable?

  Alt 2. Mär 2010, 15:33
Zitat von mkinzler:
Das geht m.W. nur wenn man die Datenbank in den singelusermodus versetzt
SQL-Code:
alter constraint <constraint> disable;
...
alter constraint <constraint> enable;
Hallo,
ich such auch nach einer Möglichkeit, die Constraints vorübergehend zu deaktivieren und später zu aktivieren.

Das Beispiel von oben scheint nicht (mehr) zu funktionieren.

Habe es mit Database Workbench probiert und auch im Singleusermodus hat es nicht geklappt:
SQL-Code:
< ERROR:
  ISC ERROR CODE:335544569
  
  ISC ERROR MESSAGE:
  Dynamic SQL Error
  SQL error code = -104
  Token unknown - line 1, column 7
  constraint
  
  STATEMENT:
  TIB_DSQL: "<TIB_Script>.<TIB_DSQL>."
Das erste Vorkommen von constraint führt shcon zum Problem.

Was läuft schief? Wie sonst kann man die constraints deaktivieren / aktivieren?
  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 10:28 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