AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Unique <> Transaktion
Thema durchsuchen
Ansicht
Themen-Optionen

Unique <> Transaktion

Ein Thema von Nico80 · begonnen am 26. Apr 2010 · letzter Beitrag vom 26. Apr 2010
Antwort Antwort
Nico80

Registriert seit: 28. Jun 2007
63 Beiträge
 
Delphi 2006 Enterprise
 
#1

Unique <> Transaktion

  Alt 26. Apr 2010, 09:46
Datenbank: Firebird • Version: 2.1 • Zugriff über: FIBPlus
Hallo,

ich habe in meiner Tabelle eine Unqiue-Spalte (über Index/Constraint).
Gibt es die Möglichkeit, das die Prüfung auf "Unique" erst nach dem Abschließen der Transaktion erfolgt.

Danke im Voraus.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Unique <> Transaktion

  Alt 26. Apr 2010, 09:54
Nein.
Warum benötigst du dies?
Markus Kinzler
  Mit Zitat antworten Zitat
Nico80

Registriert seit: 28. Jun 2007
63 Beiträge
 
Delphi 2006 Enterprise
 
#3

Re: Unique <> Transaktion

  Alt 26. Apr 2010, 10:32
Beispiel

Tabelle

ID NAME (Unique)

1 KLAUS
2 PETER

Nun möchte ich die Namen tauschen - in meiner Applikation auf speichern drücken, und das war's.
In Oracle gibt es wohl so Constraints, die innerhalb einer aktiven Transaktion nicht greifen.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Unique <> Transaktion

  Alt 26. Apr 2010, 10:46
Du könntest den Constraint kurzfristig deaktivieren oder
SQL-Code:
update <Tabelle> set name='tempwhere id = :id1;
update <Tabelle> set name = :name1 where id = :id2;
update <tabelle> set name = :name2 where id = id1;
Markus Kinzler
  Mit Zitat antworten Zitat
hoika

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

Re: Unique <> Transaktion

  Alt 26. Apr 2010, 11:32
Hallo,

Zitat:
Nun möchte ich die Namen tauschen - in meiner Applikation auf speichern drücken, und das war's.
StartTransaction

update set name='Klaus' where ...
ExecSQL;
update set name='Heinz' where ...
ExecSQL;

Commit (Transaction)


Heiko
Heiko
  Mit Zitat antworten Zitat
generic

Registriert seit: 24. Mär 2004
Ort: bei Hannover
2.416 Beiträge
 
Delphi XE5 Professional
 
#6

Re: Unique <> Transaktion

  Alt 26. Apr 2010, 11:48
Deine Namestabelle sieht aus wie eine N Tabelle.
Warum tauscht du nicht die Keys in den 1 Datensätzen aus?
Coding BOTT - Video Tutorials rund um das Programmieren - https://www.youtube.com/@codingbott
  Mit Zitat antworten Zitat
Nico80

Registriert seit: 28. Jun 2007
63 Beiträge
 
Delphi 2006 Enterprise
 
#7

Re: Unique <> Transaktion

  Alt 26. Apr 2010, 11:52
Id ist PK.

@hoika:

Beim ersten ExecSQL erfolgt eine Exception.
  Mit Zitat antworten Zitat
hoika

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

Re: Unique <> Transaktion

  Alt 26. Apr 2010, 12:32
Hallo,

hm, dann halt wie mkinzler #4.


Heiko
Heiko
  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 03:13 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