Hot News:

Unser Angebot:

  Foren auf CAD.de (alle Foren)
  Oracle
  Aktualisieren aller einträge einer Tabelle

Antwort erstellen  Neues Thema erstellen
CAD.de Login | Logout | Profil | Profil bearbeiten | Registrieren | Voreinstellungen | Hilfe | Suchen

Anzeige:

Darstellung des Themas zum Ausdrucken. Bitte dann die Druckfunktion des Browsers verwenden. | Suche nach Beiträgen nächster neuer Beitrag | nächster älterer Beitrag
Autor Thema:  Aktualisieren aller einträge einer Tabelle (1150 mal gelesen)
McByte
Mitglied
Entwicklungsingenieur


Sehen Sie sich das Profil von McByte an!   Senden Sie eine Private Message an McByte  Schreiben Sie einen Gästebucheintrag für McByte

Beiträge: 60
Registriert: 05.12.2003

erstellt am: 14. Aug. 2011 15:20    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities

Hallo,

Ich würde gerne mittels SQLPLUS eine Tabelle zeilenweise aktualisieren.
Dabei muss ich in jeder Zeile den Zielwert in Abhängigkeit von zwei anderen Werten setzen.
Ein Beispiel ist:
Wenn Wert_B gefüllt ist, dann entspricht der ZielWert Wert_B, sonst Wert_A (Siehe unten).

ID    Wert_A    Wert_B    ZielWert
-------------------------------------
0        55                            55
1        22            11            11
5        25            23            23
11      33                            33
22      64            44            44
54      68                            68

Mir ist klar, dass man mit folgendem Kommando den Wert_A in den ZielWert schreiben kann:
update TEST_TABELLE set ZielWert = (select Wert_A from TEST_TABELLE where ID='54') where ID='54'

Das problem ist, dass ich nicht weiss wie man eine Schleife über alle Zeilen realisiert.

Kann mir da jemand weiterhelfen?

Danke!

------------------
McByte

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

furter
Mitglied



Sehen Sie sich das Profil von furter an!   Senden Sie eine Private Message an furter  Schreiben Sie einen Gästebucheintrag für furter

Beiträge: 483
Registriert: 01.03.2004

Windows 7
Autodesk Map 3D 2020
AEC 2020
TOPOBASE / Oracle

erstellt am: 31. Aug. 2011 07:11    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities Nur für McByte 10 Unities + Antwort hilfreich

Hallo

So müsste dies etwa aussehen:

update TEST_TABELLE set ZIELWERT = WERT_A where WERT_B is null;
update TEST_TABELLE set ZIELWERT = WERT_B where WERT_B is not null;
commit

Damit wird die ganze Tabelle bearbeitet.
Vor dem Ausführen Sicherung nicht vergessen.


Gruss
furter

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP



Trainee CAM Softwareentwicklung (m/w/divers)

thyssenkrupp ist ein international aufgestelltes Industrie- und Technologieunternehmen mit rund 100.000 Mitarbeitenden. In 48 Ländern erwirtschaftete es im Geschäftsjahr 2022/2023 einen Umsatz von 38 Mrd ?. Mit umfassendem Technologie-Know-how entwickeln die Geschäfte wirtschaftliche und ressourcenschonende Lösungen für die Herausforderungen der Zukunft, vor allem in den Bereichen Klimaschutz und Energiewende, digitaler Transformation in der Industrie sowie Mobilität der Zukunft....

Anzeige ansehenFertigung, Produktion
Stelli1
Moderator
Verm.-Ing.


Sehen Sie sich das Profil von Stelli1 an!   Senden Sie eine Private Message an Stelli1  Schreiben Sie einen Gästebucheintrag für Stelli1

Beiträge: 1521
Registriert: 17.08.2005

Map 2000-2012, Rasterdesign
MapGuide 6.5 - 2012
Oracle
Autodesk Topobase 2-2012
VS6, VS.net

erstellt am: 27. Sep. 2011 11:49    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities Nur für McByte 10 Unities + Antwort hilfreich

Hallo,

wie Furter es schreibt geht das.

EIne andere Variante in einer Zeile wäre:

Code:
update tabelle set ZielWert= nvl(Wert_B,Wert_A);

Übersetzt wäre das: Schreibe in die Spalte Zielwert den Wert_B aber wenn der NULL ist nehme den Wert_A

Gruß
Wilfried Stelberg

------------------
Warum lisp'eln wenn's auch anders geht.
www.ib-stelberg.de

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

Anzeige.:

Anzeige: (Infos zum Werbeplatz >>)

Darstellung des Themas zum Ausdrucken. Bitte dann die Druckfunktion des Browsers verwenden. | Suche nach Beiträgen

nächster neuerer Beitrag | nächster älterer Beitrag
Antwort erstellen


Diesen Beitrag mit Lesezeichen versehen ... | Nach anderen Beiträgen suchen | CAD.de-Newsletter

Administrative Optionen: Beitrag schliessen | Archivieren/Bewegen | Beitrag melden!

Fragen und Anregungen: Kritik-Forum | Neues aus der Community: Community-Forum

(c)2023 CAD.de | Impressum | Datenschutz