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 3 von 3     123   
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.624 Beiträge
 
Delphi 12 Athens
 
#21

AW: SQL Update alle Einträge

  Alt 21. Jun 2010, 19:39
[ code=SQL ] (ohne Leerzeichen natürlich)
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
alex517

Registriert seit: 23. Nov 2004
Ort: Bernau b. Berlin
273 Beiträge
 
Delphi XE5 Enterprise
 
#22

AW: SQL Update alle Einträge

  Alt 21. Jun 2010, 20:11
[ code=SQL ] (ohne Leerzeichen natürlich)
Danke.
Aber im Moment stelle ich mich noch zu blöd an (siehe #20), aber vllt. lern ich's ja noch.
Alexander
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: SQL Update alle Einträge

  Alt 21. Jun 2010, 20:18
MERGE gab es nur in der alpha
Und wurde später durch Update or Insert ersetzt

SQL-Code:
Update Or Insert into <Tabelle> (<Feldliste>)
values ( <Werteliste> )
matching (<Feldliste übereinstimmnde Felder>);
Der SQL-Tag ist eine Erweiterung des Code-Tags; diesen einfach um =SQL erweitern
Markus Kinzler
  Mit Zitat antworten Zitat
alex517

Registriert seit: 23. Nov 2004
Ort: Bernau b. Berlin
273 Beiträge
 
Delphi XE5 Enterprise
 
#24

AW: SQL Update alle Einträge

  Alt 21. Jun 2010, 21:25
MERGE gab es nur in der alpha
Und wurde später durch Update or Insert ersetzt
allerdings ist in Firebird das
MERGE INTO.. um einiges mächtiger als das Update or Insert .
wobei beide ihre Berechtigung haben. Aber ich glaube das ist auch schon Off Topic


Zitat von mkinzler:
Der SQL-Tag ist eine Erweiterung des Code-Tags; diesen einfach um =SQL erweitern
Mich wunderte nur, warum das "SQL-Code:" bei manchen erscheint, bei mir aber nicht
Aber jetzt hab ich's begriffen.
Alexander

Geändert von alex517 (21. Jun 2010 um 21:28 Uhr)
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: SQL Update alle Einträge

  Alt 21. Jun 2010, 21:31
Und was war am MERGE mächtiger?
Markus Kinzler
  Mit Zitat antworten Zitat
alex517

Registriert seit: 23. Nov 2004
Ort: Bernau b. Berlin
273 Beiträge
 
Delphi XE5 Enterprise
 
#26

AW: SQL Update alle Einträge

  Alt 21. Jun 2010, 22:32
Und was war am MERGE mächtiger?
IST!
Bsp. aus der Firebird.Docs:
SQL-Code:
      MERGE
         INTO customers c
         USING (SELECT * FROM customers_delta WHERE id > 10) cd
         ON (c.id = cd.id)
         WHEN MATCHED THEN
            UPDATE SET name = cd.name
         WHEN NOT MATCHED THEN
            INSERT (id, name)
               VALUES (cd.id, cd.name)
Beim "UPDATE OR INSERT" werden IMMER entwerder INSERT oder UPDATE ausgeführt.
Dabei werden beim INSERT und UPDATE die GLEICHEN Felder eingefügt/geändert.

Beim Merge hat man die Möglichkeit beim Update andere Felder als beim Insert zu setzen. Und man kann eine von beiden Operationen wegzulassen.

Um wieder zu Thema "SQL Update alle Einträge" zurückzukehren:
In diesem Fall, es fände nur der ..WHEN MATCHED THEN UPDATE SET .. -Zweig
Verwendung, ..WHEN NOT MATCHED THEN INSERT .. würde man weglassen.

Ein Geschwindigkeitsvorteil gegenüber einem einfachen "UPDATE .. SET = (Select.. From..)"
ergibt sich wenn mehrer Felder der Zieltabelle aus gleichzeitig geändert werden.

SQL-Code:
      
  MERGE INTO customers c
   USING (SELECT * FROM customers_delta WHERE id > 10) cd
   ON (c.id = cd.id)
   WHEN MATCHED THEN
     UPDATE SET
       name = cd.name,
       FeldX = cd.ZZ,
       FeldY = cd.TTT;
Alexander
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 3 von 3     123   


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 12:35 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