![]() |
Datenbank: Firebird • Version: 1.5 • Zugriff über: IBConsole
Update mit Werten aus zweiter Tabelle
Ich hab zwei Tabellen, eine Artikel und eine MATERIAL Tabelle.
Jetzt möchte ich, das ich mit einem UPDATE das Feld GEPLANT in der Tabelle Artikel um den Wert erhöhe, wie das Feld Menge in der Tabelle MATERIAL.
SQL-Code:
kann ich das mit folgendem UPDATE machen ?
vorher :
ARTIKEL ID GEPLANT 1 0 2 5 3 6 MATERIAL ID TEIL ARTIKEL MENGE 1 1 1 5 2 1 3 4 3 1 1 2 nachher ARTIKEL ID GEPLANT 1 7 2 9 3 6
SQL-Code:
muß ich da noch irgendwie einen WHERE für das UPDATE zusammenbringen, oder reicht das so ?
UPDATE ARTIKEL SET GEPLANT = GEPLANT + (SELECT SUM(MENGE) FROM MATERIAL WHERE MATERIAL.ARTIKEL = ARTIKEL.ID AND MATERIAL.TEIL = 1);
|
Re: Update mit WErten aus zweiter Tabelle
Hallo Hans,
wenn du alle Artikel updaten möchtest, brauchst du keine Eingrenzug mit Where. Allerdings kann dein SubSelect auch ein null liefern, da in der Tabelle Material nicht alle Artikel sind. Ich würde da noch ein coalesce drum machen:
SQL-Code:
Cu, Frank
UPDATE ARTIKEL SET GEPLANT = GEPLANT +
coalesce(SELECT SUM(MENGE) FROM MATERIAL WHERE MATERIAL.ARTIKEL = ARTIKEL.ID AND MATERIAL.TEIL = 1), 0); |
Re: Update mit WErten aus zweiter Tabelle
Hi
Also, in der ARTIKEL Tabelle sind über 2000 Datensätze in der MATERIAL Tabelle sind so 10-20 Datensaätze, also wäre es eventuell geschickter noch ein WHERE fürs UPDATE zu machen, damit nicht alle Artikel geupdatet werden oder ?
SQL-Code:
oder kann man das noch elegenater lösen ?
UPDATE ARTIKEL SET GEPLANT = GEPLANT +
coalesce(SELECT SUM(MENGE) FROM MATERIAL WHERE MATERIAL.ARTIKEL = ARTIKEL.ID AND MATERIAL.TEIL = 1), 0) WHERE ID IN (SELECT ARTIKEL FROM MATERIAL WHERE TEIL = 1); |
Re: Update mit WErten aus zweiter Tabelle
Zitat:
Hier würde ich eine Procedure schreiben, wo du einen group select über Material machst und diesen dann durchläufst und Artikel updatest. Ungetestet:
SQL-Code:
Cu, Frank
CREATE PROCEDURE UPDATE_ARTIKEL_GEPLANT
AS DECLARE VARIABLE ID INTEGER; DECLARE VARIABLE MENGE INTEGER; begin for select artikel, sum(menge) from material where teil=1 group by artikel into :id, :menge do update artikel set geplant = geplant + :menge where id = :id; end |
Re: Update mit Werten aus zweiter Tabelle
Danke nochmal, mußte nur beim INTO die : weggeben und jetzt passts
muß nur noch das in den GRiff bekommen : ![]() |
Alle Zeitangaben in WEZ +1. Es ist jetzt 11:59 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz