AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken SQL update mit Bedingung aus anderer Tabelle
Thema durchsuchen
Ansicht
Themen-Optionen

SQL update mit Bedingung aus anderer Tabelle

Ein Thema von noisy_master · begonnen am 3. Dez 2020 · letzter Beitrag vom 5. Dez 2020
Antwort Antwort
noisy_master

Registriert seit: 17. Jun 2009
Ort: Wolfenbüttel/Baddeckenstedt
260 Beiträge
 
Delphi XE5 Professional
 
#1

SQL update mit Bedingung aus anderer Tabelle

  Alt 3. Dez 2020, 10:48
Datenbank: Paradox • Version: xx • Zugriff über: BDE
Hallo Gemeinde,

auch für mich geht endlich die Zeit der BDE vorbei, aber vorher muss ich noch ein kleines Update fertig machen.
Ich stehe vor folgendem Problem:

Ich habe zwei Tabellen A und B. Beide Tabellen haben ein bool Feld(DORESET). Tabelle A KANN(!) eine Referenz zu Tabelle B haben, muss aber nicht (Feld: REFERENCE). Nun muss ich in Tabelle A ein Feld(AKTWERT) auf 0 setzen, wenn entweder
1. A.REFERENCE=NULL and A.DORESET=TRUE
oder
2. A.REFERECE != NULL and B.DORESET=TRUE (wobei B = A.REFERENCE ist).

Teil 1 ist einfach :
UPDATE A SET AKTWERT=0 WHERE DORESET=TRUE AND REFERENCE IS NULL

Für die 2. Variante habe ich aber absolut keine Ahnung, wie ich das hinbekomme. Geht das überhaupt in einem Command? Hat da irgendjemand eine Idee?

Ich danke schonmal wieder im voraus!

Und ja: ich werde die BDE bald endgültig einstampfen

Gruß
Dirk
  Mit Zitat antworten Zitat
Delphi.Narium

Registriert seit: 27. Nov 2017
2.490 Beiträge
 
Delphi 7 Professional
 
#2

AW: SQL update mit Bedingung aus anderer Tabelle

  Alt 3. Dez 2020, 11:20
Bevor ich ein Update mache, schaue ich erstmal, ob ich ein passendes Select hinbekomme, um mir die Daten ansehen zu können.

Der Umbau auf Update ist dann (meist) recht einfach, da sich die Wherebedingung ja nicht ändert.
SQL-Code:
select a.Reference, b.Reference, b.DoReset
from a, b
where a.Reference = b.Reference
and a.Reference is not null
and b.DoReset = true
Wenn das das richtige Ergebnis liefert, könnte der "Rest" ungefähr so aussehen:
SQL-Code:
update a set Aktwert = 0
where a.Reference in (
  select a.Reference
  from a, b
  where a.Reference = b.Reference
  and a.Reference is not null
  and b.DoReset = true
)
Und nein, ein Performancekunstwerk wird dieses Statement ganz bestimmt nicht werden
Aber für ein "brauch' ich nur einmal" sollte es reichen.
  Mit Zitat antworten Zitat
noisy_master

Registriert seit: 17. Jun 2009
Ort: Wolfenbüttel/Baddeckenstedt
260 Beiträge
 
Delphi XE5 Professional
 
#3

AW: SQL update mit Bedingung aus anderer Tabelle

  Alt 4. Dez 2020, 08:14
UI, toll!

Vielen Dank!! Sieht so aus als würde es mein Problem lösen!!!
Jetzt noch eine vermessene Frage:

Bekommt ihr SQL Gurus das auch hin, Teil 1 und 2 zu kombinieren? Ist kein muss, aber sähe schon geil aus

Danke
Gruß
Dirk
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: SQL update mit Bedingung aus anderer Tabelle

  Alt 4. Dez 2020, 08:48
Beide Bedingungen in ein OR packen
SQL-Code:
update a set Aktwert = 0
where a.Reference in (
  select
    a.Reference
  from
    a, b
  where
    (a.Reference is null and
     a.DORESET is true) or
    (a.Reference = b.Reference and
     a.Reference is not null and
     b.DoReset = true)
)
Markus Kinzler
  Mit Zitat antworten Zitat
noisy_master

Registriert seit: 17. Jun 2009
Ort: Wolfenbüttel/Baddeckenstedt
260 Beiträge
 
Delphi XE5 Professional
 
#5

AW: SQL update mit Bedingung aus anderer Tabelle

  Alt 4. Dez 2020, 16:09
ok,ok....Wald und Bäume und so...

DANKE vielmals!
Dirk
  Mit Zitat antworten Zitat
Rollo62

Registriert seit: 15. Mär 2007
4.067 Beiträge
 
Delphi 12 Athens
 
#6

AW: SQL update mit Bedingung aus anderer Tabelle

  Alt 5. Dez 2020, 09:13
ok,ok....Wald und Bäume und so...

DANKE vielmals!
Damit man Bäume besser erkennt formatiere ich das in komplexen Fällen auch gerne so:
Delphi-Quellcode:
  where
        ( a.Reference is null
          and a.DORESET is true)
    or ( a.Reference = b.Reference
          and a.Reference is not null
          and b.DoReset = true)
Edit:
Sorry die Forensuftware killt immer die Formatierungen
clipboard02.jpg

Geändert von Rollo62 ( 5. Dez 2020 um 09:15 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu
Online

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

AW: SQL update mit Bedingung aus anderer Tabelle

  Alt 5. Dez 2020, 12:05
Verwende [CODE] statt [DELPHI], dort ist das nicht "ganz" so schlimm,

abgesehn davon, dass es eh kein Delphi-Code ist , also vielleicht auch mal [CODE=SQL] versuchen. [EDIT] Nein, dort sind leider auch die Leerzeichen falsch. [/EDIT]



PS: Vielleicht auch mal auf einwas Einigen?
SQL-Code:
and x.DoReset is true
and x.DoReset = true
and x.DoReset -- es ist ja schon ein Boolean
Und das AND "kann" weg, denn NULL wird vom = sowieso nicht durchgelassen.
SQL-Code:
where a.Reference = b.Reference
and a.Reference is not null

Was ist eigentlich mit a.ref=b.ref aber a.reset kein True (null oder false), oder zählt das Reset immer nur vom Letzten?
SQL-Code:
where (a.Reference is null
    and a.DoReset)
  or (a.Reference = b.Reference
    and b.DoReset) -- hier auch noch "and a.DoReset" mit rein?

where a.DoReset -- oder für Alles, weil es ja doppelt und in jedem OR drin wäre
  and (a.Reference is null
   or (a.Reference = b.Reference
     and b.DoReset))
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests

Geändert von himitsu ( 5. Dez 2020 um 12:24 Uhr)
  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 20:46 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