AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Sonstige Fragen zu Delphi Delphi Spalte hat den Wert Null und lässt sich nicht updaten
Thema durchsuchen
Ansicht
Themen-Optionen

Spalte hat den Wert Null und lässt sich nicht updaten

Ein Thema von Walter Landwehr · begonnen am 2. Okt 2018 · letzter Beitrag vom 3. Okt 2018
Antwort Antwort
Seite 1 von 2  1 2      
Walter Landwehr

Registriert seit: 28. Mär 2006
Ort: 32816 Schieder-Schwalenberg
384 Beiträge
 
Delphi 10.4 Sydney
 
#1

Spalte hat den Wert Null und lässt sich nicht updaten

  Alt 2. Okt 2018, 14:36
Hallo, ich habe eine Tabelle mit einer Spalte (ANZAHLMAIL) . Nun will ich per SQL Update die Spalte um 1 erhöhen.
update TBL_MANDANT set MAILANZAHL = MAILANZAHL + 1 Der SQL Befehl wird ausgeführt aber die Spalte ist immer noch NULL, Warum?

Hat die Spate den Wert >= 0 dann funktioniert es. Wie kann ich das umgehen das auch bei Null der Update Befehl funktioniert.
Walter Landwehr
Mfg

Walter
  Mit Zitat antworten Zitat
sko1

Registriert seit: 27. Jan 2017
577 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#2

AW: Spalte hat den Wert Null und lässt sich nicht updaten

  Alt 2. Okt 2018, 15:02
NULL ist halt was anderes als 0 !

NULL ist leer und damit kann Dein SQL-Statement nix anfangen...

Ciao
Stefan
  Mit Zitat antworten Zitat
DasWolf

Registriert seit: 7. Jun 2016
75 Beiträge
 
Delphi 10.1 Berlin Professional
 
#3

AW: Spalte hat den Wert Null und lässt sich nicht updaten

  Alt 2. Okt 2018, 15:25
Probiere mal folgendes:

Code:
update TBL_MANDANT set MAILANZAHL = ISNULL(MAILANZAHL, 0) + 1
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: Spalte hat den Wert Null und lässt sich nicht updaten

  Alt 2. Okt 2018, 15:46
NULL plus/minus/und/oder Irgendwas ist immer NULL.
Bei Google suchennull arithmetic

COALESCE, ISNULL usw. sind mögliche Lösungen.
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests
  Mit Zitat antworten Zitat
TigerLilly

Registriert seit: 24. Mai 2017
Ort: Wien, Österreich
1.174 Beiträge
 
Delphi 11 Alexandria
 
#5

AW: Spalte hat den Wert Null und lässt sich nicht updaten

  Alt 2. Okt 2018, 15:56
Aber Achtung: Eben weil NULL nicht das selbe wie 0 ist, sollte man NULL und 0 nicht gleich setzen. Die Frage ist, warum ein Feld NULL enthält, obwohl es doch 0 enthalten sollte.

Vielleicht wäre eine DEFAULT Klausel bei der Tabellenerstellung sinnvoll oder eine Initialisierung beim INSERT.
  Mit Zitat antworten Zitat
Walter Landwehr

Registriert seit: 28. Mär 2006
Ort: 32816 Schieder-Schwalenberg
384 Beiträge
 
Delphi 10.4 Sydney
 
#6

AW: Spalte hat den Wert Null und lässt sich nicht updaten

  Alt 2. Okt 2018, 16:08
ISNULL kennt Firebird nicht. Ich denke ich muss nach dem einfügen der Spalte den Wert auf 0 setzten.
Walter Landwehr
Mfg

Walter
  Mit Zitat antworten Zitat
Benutzerbild von Neutral General
Neutral General

Registriert seit: 16. Jan 2004
Ort: Bendorf
5.219 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#7

AW: Spalte hat den Wert Null und lässt sich nicht updaten

  Alt 2. Okt 2018, 16:12
ISNULL kennt Firebird nicht. Ich denke ich muss nach dem einfügen der Spalte den Wert auf 0 setzten.
Wie himitsu schon gesagt hat: coalesce ist was du brauchst:
Code:
update TBL_MANDANT set MAILANZAHL = coalesce(MAILANZAHL, 0) + 1
Michael
"Programmers talk about software development on weekends, vacations, and over meals not because they lack imagination,
but because their imagination reveals worlds that others cannot see."
  Mit Zitat antworten Zitat
Walter Landwehr

Registriert seit: 28. Mär 2006
Ort: 32816 Schieder-Schwalenberg
384 Beiträge
 
Delphi 10.4 Sydney
 
#8

AW: Spalte hat den Wert Null und lässt sich nicht updaten

  Alt 2. Okt 2018, 16:13
Dank himitsu,

das funktioniert.

update TBL_MANDANT set MAILANZAHL = COALESCE(MAILANZAHL, 0) + 1
Walter Landwehr
Mfg

Walter
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: Spalte hat den Wert Null und lässt sich nicht updaten

  Alt 2. Okt 2018, 16:16
NULLIF, COLAESCE,

IIF( <Spalte> is Null, 1, <Spalte> = <Spalte> +1)
SQL-Code:
case <Spalte>
  when null then 1
  else <Spalte> = <Spalte> +1
end
Markus Kinzler
  Mit Zitat antworten Zitat
TigerLilly

Registriert seit: 24. Mai 2017
Ort: Wien, Österreich
1.174 Beiträge
 
Delphi 11 Alexandria
 
#10

AW: Spalte hat den Wert Null und lässt sich nicht updaten

  Alt 2. Okt 2018, 17:01
Nocheinmal: Wenn man seine Tabellen von Anfang an g´scheit definiert braucht es nachher keine komplizierten Kopfstände.

Merke: NULL <> 0

ISNULL, IIF, COALESCE, WHEN in Kombination mit NULL sind immer ein Zeichen für mangelhaftes Design.
  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 20:57 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