Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Daten aus einer Tabellenkopie wieder in Original schreiben (https://www.delphipraxis.net/123677-daten-aus-einer-tabellenkopie-wieder-original-schreiben.html)

PASST 6. Nov 2008 13:21

Datenbank: MS SQL Server • Version: 2000 • Zugriff über: gar nicht mit Delphi

Daten aus einer Tabellenkopie wieder in Original schreiben
 
Hallo allerseits,

ich möchte in einer Tabelle die Daten eines Feldes ändern. Als Backup habe ich nicht die ganze DB gesichert, sondern nur eine Kopie der Tabelle in der DB angelegt. Ich möchte das ganze per SQL, also letztendlich unabhängig von Delphi mit dem SQL Query Analyzer lösen.

Jetzt möchte ich wg eines Fehlers das ganze wieder rückgängig machen. Dazu reicht es mir ein bestimmtes Feld aus der Kopie in die Originaltabelle zurückschreiben.

Der SQL-Text funktioniert aber nicht.
SQL-Code:
UPDATE tbl_a a
SET a.feld_1 = (SELECT b.feld_1 FROM kopie_a b WHERE b.feld_id = a.feld_id)
WHERE EXISTS
 (SELECT b.feld_1 FROM kopie_a b WHERE b.feld_id = a.feld_id)
Dieser Code zeigt aber schon beim Parsen Fehler.
SQL-Code:
Server: Msg 170, Level 15, State 1, Line 4
Line 4: Incorrect syntax near 'a'.
Server: Msg 156, Level 15, State 1, Line 6
Incorrect syntax near the keyword 'where'.
Was mache ich falsch?

Gruß,
Peter

PASST 6. Nov 2008 13:28

Re: Daten aus einer Tabellenkopie wieder in Original schreib
 
Ich habe die Lösung gefunden :)
Vielleicht sollte ich etwas länger überlegen und alle Hilfe durchlesen, die ich finden kann, bevor ich das nächste mal eine Frage stelle.

SQL-Code:
update tbl_a
set tbl_a.feld_1 = (select kopie_a.feld_1 from kopie_a where kopie_a.feld_id = tbl_a.feld_id)
from tbl_a, kopie_a


Alle Zeitangaben in WEZ +1. Es ist jetzt 14:02 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