AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi warum funktioniert dieses update nicht?
Thema durchsuchen
Ansicht
Themen-Optionen

warum funktioniert dieses update nicht?

Ein Thema von webcss · begonnen am 12. Okt 2007 · letzter Beitrag vom 12. Okt 2007
Antwort Antwort
Seite 1 von 2  1 2      
webcss

Registriert seit: 10. Feb 2006
255 Beiträge
 
Delphi XE2 Professional
 
#1

warum funktioniert dieses update nicht?

  Alt 12. Okt 2007, 07:59
Datenbank: Firebird • Version: 2.0.3 • Zugriff über: ibexpert
moin DPler,

folgendes update liefert nicht das gewünschte ergebnis:
SQL-Code:
update adressen set
KundenRef = (select kunden.Id from kunden where kunden.adresseRef = adressen.ID)
und ich raff's net wieso?

HILFE!
"Wer seinem Computer Mist erzählt, muss immer damit rechnen..." (unbekannt)
"Der Computer rechnet damit, dass der Mensch denkt..." (auch unbekannt)
mein blog
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

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

Re: warum funktioniert dieses update nicht?

  Alt 12. Okt 2007, 08:01
Und so?
SQL-Code:
update adressen set
KundenRef = (select kunden.Id from kunden,adressen where kunden.adresseRef = adressen.ID)
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
mkinzler
(Moderator)

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

Re: warum funktioniert dieses update nicht?

  Alt 12. Okt 2007, 08:04
Oder
SQL-Code:
update adressen a set
KundenRef = (select kunden.Id from kunden where kunden.adresseRef = a.ID)
Markus Kinzler
  Mit Zitat antworten Zitat
webcss

Registriert seit: 10. Feb 2006
255 Beiträge
 
Delphi XE2 Professional
 
#4

Re: warum funktioniert dieses update nicht?

  Alt 12. Okt 2007, 08:11
Zitat von DeddyH:
Und so?
SQL-Code:
update adressen set
KundenRef = (select kunden.Id from kunden,adressen where kunden.adresseRef = adressen.ID)
multiple rows in singleton select

Zitat von mkinzler:
update adressen a set
KundenRef = (select kunden.Id from kunden where kunden.adresseRef = a.ID)
das ist dasselbe was ich mache, zumindest im ergebnis...
"Wer seinem Computer Mist erzählt, muss immer damit rechnen..." (unbekannt)
"Der Computer rechnet damit, dass der Mensch denkt..." (auch unbekannt)
mein blog
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

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

Re: warum funktioniert dieses update nicht?

  Alt 12. Okt 2007, 08:19
Noch ein Versuch aus dem Kopf:
SQL-Code:
UPDATE Adressen A
SET KundenRef =
(SELECT kunden.Id FROM kunden
 JOIN Adressen B ON B.adressenId = kunden.adresseRef)
WHERE A.Id = B.Id
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 mirage228
mirage228

Registriert seit: 23. Mär 2003
Ort: Münster
3.750 Beiträge
 
Delphi 2010 Professional
 
#6

Re: warum funktioniert dieses update nicht?

  Alt 12. Okt 2007, 08:20
Zitat von webcss:
Zitat von DeddyH:
Und so?
SQL-Code:
update adressen set
KundenRef = (select kunden.Id from kunden,adressen where kunden.adresseRef = adressen.ID)
multiple rows in singleton select
Hört sich zumindest so an, als ob das Sub-Select mehrere Ergebnisse liefert, wo nur eines erlaubt wäre.
Was ist wenn du ein "LIMIT 1" in die Select-Anweisung reinschreibst?

mfG
mirage228
David F.

May the source be with you, stranger.
PHP Inspection Unit (Delphi-Unit zum Analysieren von PHP Code)
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

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

Re: warum funktioniert dieses update nicht?

  Alt 12. Okt 2007, 08:21
Firebird kennt kein "LIMIT" (leider weiß ich jetzt nicht aus dem Kopf, wie dort die Entsprechung lautet).
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
mkinzler
(Moderator)

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

Re: warum funktioniert dieses update nicht?

  Alt 12. Okt 2007, 08:29
Zitat:
Firebird kennt kein "LIMIT" (leider weiß ich jetzt nicht aus dem Kopf, wie dort die Entsprechung lautet).
select first 1 ... bzw. Interbase Syntax
select ... rows 1 oder halt mit distinct
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

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

Re: warum funktioniert dieses update nicht?

  Alt 12. Okt 2007, 08:30
Thx, wieder was gelernt.
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
webcss

Registriert seit: 10. Feb 2006
255 Beiträge
 
Delphi XE2 Professional
 
#10

Re: warum funktioniert dieses update nicht?

  Alt 12. Okt 2007, 08:45
Zitat von DeddyH:
Noch ein Versuch aus dem Kopf:
SQL-Code:
UPDATE Adressen A
SET KundenRef =
(SELECT kunden.Id FROM kunden
 JOIN Adressen B ON B.adressenId = kunden.adresseRef)
WHERE A.Id = B.Id
geht nicht da man sich in einem "äußeren" where-clause auf spalten eines SubSelects beziehen kann. Trotzdem Danke.
"Wer seinem Computer Mist erzählt, muss immer damit rechnen..." (unbekannt)
"Der Computer rechnet damit, dass der Mensch denkt..." (auch unbekannt)
mein blog
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 16:43 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