AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

SQL Update alle Einträge

Ein Thema von ibp · begonnen am 21. Jun 2010 · letzter Beitrag vom 21. Jun 2010
Antwort Antwort
Seite 1 von 3  1 23      
Benutzerbild von ibp
ibp

Registriert seit: 31. Mär 2004
Ort: Frankfurt am Main
1.511 Beiträge
 
Delphi 7 Architect
 
#1

SQL Update alle Einträge

  Alt 21. Jun 2010, 12:42
Datenbank: Interbase • Version: 6.5 • Zugriff über: SQL
Hallo,

gibt es eine Möglichkeit mit einer UPDATE Anweisung alle Datensätze zu ändern ABER mit unterschiedlichen Werten für die einzelnen Datensätze?

Struktur:
Tab1 (pkey,reckey,sortstr)
Tab2 (pkey,f1,f2,...fn)

Tab1.reckey=Tab2.pkey

Es kann mehrere Datensätze in Tab1 geben die den gleichen reckey haben!

Was gemacht werden soll: Tab1.sortstr soll aktualisiert werden. Dabei entspricht Tab1.sortstr=concat(tab2.f5+tab2.f1+...)

Wie bekomme ich das mit einem SQL-Statement hin ohne alle Datensätze in Tab2 durchlaufen zu müssen?

Hat jemand einen Tipp?
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: SQL Update alle Einträge

  Alt 21. Jun 2010, 12:44
Und wie unterscheiden sich die Werte? Ist der neue Wert berechenbar?
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von ibp
ibp

Registriert seit: 31. Mär 2004
Ort: Frankfurt am Main
1.511 Beiträge
 
Delphi 7 Architect
 
#3

AW: SQL Update alle Einträge

  Alt 21. Jun 2010, 12:51
Und wie unterscheiden sich die Werte? Ist der neue Wert berechenbar?
Nein die neuen Werte sind nicht berechenbar. Es werden die Felder nach einer bestimmten Definition aus Tab2 zusammengefügt.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: SQL Update alle Einträge

  Alt 21. Jun 2010, 12:53
Dann sind sie ja "berechenbar/ermittelbar"
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.542 Beiträge
 
Delphi 11 Alexandria
 
#5

AW: SQL Update alle Einträge

  Alt 21. Jun 2010, 12:53
Falls ich Dich richtig verstanden habe kannst Du es mal so versuchen:
SQL-Code:
UPDATE Tab1
SET sortstr = (
  SELECT Tab2.f5 || Tab2.f1 || ...
  FROM Tab2
  WHERE Tab2.pkey = Tab1.reckey)
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Benutzerbild von ibp
ibp

Registriert seit: 31. Mär 2004
Ort: Frankfurt am Main
1.511 Beiträge
 
Delphi 7 Architect
 
#6

AW: SQL Update alle Einträge

  Alt 21. Jun 2010, 13:08
also mit
Code:
select (tab2.f2||tab3.fx ...)
from tab1
left outer join tab2 an (tab1.reckey=tab2.pkey)
erhalte ich die richtige Ergebnismenge aber leider meckert interbase beim update mit "multiple rows in singleton select"
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: SQL Update alle Einträge

  Alt 21. Jun 2010, 13:09
Der Subquery liefert mehrere Ergebniszeilen; du musst diesen so anpassen, dass genau ein Ergebnis rauskommt.
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.542 Beiträge
 
Delphi 11 Alexandria
 
#8

AW: SQL Update alle Einträge

  Alt 21. Jun 2010, 13:13
Dann habe ich die Master-Detail-Beziehung doch falsch verstanden (oder sie war falsch geschildert).
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Benutzerbild von ibp
ibp

Registriert seit: 31. Mär 2004
Ort: Frankfurt am Main
1.511 Beiträge
 
Delphi 7 Architect
 
#9

AW: SQL Update alle Einträge

  Alt 21. Jun 2010, 13:16
Der Subquery liefert mehrere Ergebniszeilen; du musst diesen so anpassen, dass genau ein Ergebnis rauskommt.
ja aber genau das will ich ja nicht, ich will gleichzeitig alle Datensätze in Tab1 updaten aber eben nicht mit einem Wert sondern mit verschiedenen, die sind abhängig von den verknüpften Datensätzen...
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.542 Beiträge
 
Delphi 11 Alexandria
 
#10

AW: SQL Update alle Einträge

  Alt 21. Jun 2010, 13:21
Er meint je zu aktualisierendem Datensatz ein Datensatz aus der Subquery. Im Moment kommen in Letzterer noch mehrere, da musst Du die Kriterien anpassen, damit nur der eine passende kommt.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 3  1 23      


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 00:05 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