Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Problem beim ändern von Datensätzen (https://www.delphipraxis.net/171090-problem-beim-aendern-von-datensaetzen.html)

Captnemo 19. Okt 2012 14:00

Datenbank: MSSQL Express Edition • Version: 2005 • Zugriff über: ADO

Problem beim ändern von Datensätzen
 
Hi, ich habe ein Problem bei einer SQL-Anweisung und finde den Fehler nicht.

Mein SQL-Statement
Code:
Update items SET mwstname=:mwstnameneu, mwstsatz=:mwstsatz where
mandantGUID=:mandantGUID and mwstname=:mwstnamealt and bill=0
In meine Code hab ich:
Delphi-Quellcode:
      dm1.q_update_items_mwst.Parameters.ParseSQL(dm1.q_update_items_mwst.SQL.Text, True);
      dm1.q_update_items_mwst.Parameters.ParamValues['mandantGUID']:=GUIDToString(frm_main.MandantGuid);
      dm1.q_update_items_mwst.Parameters.ParamValues['mwstnamealt']:=cbb_von.Text;
      dm1.q_update_items_mwst.Parameters.ParamValues['mwstnameneu']:=mwst;
      dm1.q_update_items_mwst.Parameters.ParamValues['mwstsatz']:=satz;
      dm1.q_update_items_mwst.ExecSQL;
Und bekomme folgende Fehlermeldung

Zitat:

Exception der Klasse EOleException mit der Meldung 'die Datentypen varchar und ntext sind im equal to-Operator inkompatibel' aufgetreten
Die Datenfelder sind:
mandantGUID = uniqueidentifier
mwstname = varchar(200)
mwstsatz = float

Ziel ist es, alle Datensätze mit einem bestimmten Namen in mwstname mit einem neuen mwstname und mwstsatz zu versehen.

Worin liegt mein Fehler?

mkinzler 19. Okt 2012 14:03

AW: Problem beim ändern von Datensätzen
 
Und bill?

Captnemo 19. Okt 2012 14:04

AW: Problem beim ändern von Datensätzen
 
Wow, bist du fix. :-)

Sorry, hab ich vergessen.

Bill = Integer;

shmia 19. Okt 2012 14:48

AW: Problem beim ändern von Datensätzen
 
In deiner Tabelle gibt es anscheinend ein Feld vom Typ ntext.
Dieser Datentyp enthält Widechar-Daten (erkennbar an dem n) und ist längenmässig unbeschränkt.
Mit text und ntext Datentypen sollte man beim SQL Server nur verwenden, wenn man es unbedingt braucht.

Du behauptest ja
Code:
mwstname = varchar(200)
, aber vielleicht hast du ja in der falschen Datenbank nachgeschaut.


PS:
Du solltest die Tabelle nicht "Items" nennen.
Suche dir einen ausagekräftigen Namen.

Captnemo 19. Okt 2012 15:03

AW: Problem beim ändern von Datensätzen
 
Gut, der Name Items ist vielleicht nicht so ganz glücklich gewählt, aber bisher haben sämtliche Selects, Inserts, Updates und Deletes damit keine Probleme verursacht.

Ich habe in der Tabelle noch ein Feld "Kommentar" vom Typ Text. Aber zum einen ist das schon von anfang an drin, und zum anderen wird das in diesem Statement ja nicht angesprochen, und sollte eigentlich auch nicht das Problem sein. Macht bei anderen Updates dieser Tabelle auch keine Probleme.

Ich bin ganz sicher auf der richtigen Tabelle / DB. Das habe ich mehrfach überprüft. Ich habe auch die Felder schon entfernt und wieder hinzugefügt.

Varchar ist ja nicht so was ganz außergewöhnliches.

shmia 19. Okt 2012 15:19

AW: Problem beim ändern von Datensätzen
 
Zitat:

Zitat von Captnemo (Beitrag 1187625)
Ich habe in der Tabelle noch ein Feld "Kommentar" vom Typ Text.

In der Fehlermeldung steht aber ntext!
Ich glaube nicht, dass das Feld "Kommentar" die Ursache der Probleme ist.
Zitat:

Zitat von Captnemo (Beitrag 1187625)
Varchar ist ja nicht so was ganz außergewöhnliches.

Das Problem ist das ntext - Feld oder ntext-Parameter.
Ich würde testweise jeweils einen Parameter durch einen festen Wert ersetzen.
Delphi-Quellcode:
q_update_items_mwst.SQL.Text :=
'Update items SET mwstname=:mwstnameneu, mwstsatz=:mwstsatz where mandantGUID=:mandantGUID and mwstname=''alt'' and bill=0';
q_update_items_mwst.Parameters.ParseSQL(dm1.q_update_items_mwst.SQL.Text, True);
q_update_items_mwst.Parameters.ParamValues['mandantGUID']:=GUIDToString(frm_main.MandantGuid);
//q_update_items_mwst.Parameters.ParamValues['mwstnamealt']:=cbb_von.Text;
q_update_items_mwst.Parameters.ParamValues['mwstnameneu']:=mwst;
q_update_items_mwst.Parameters.ParamValues['mwstsatz']:=satz;
q_update_items_mwst.ExecSQL;
Zitat:

Zitat von Captnemo (Beitrag 1187625)
der Name Items ist vielleicht nicht so ganz glücklich gewählt, aber bisher haben sämtliche Selects, Inserts, Updates und Deletes damit keine Probleme verursacht.

Je früher man solche Dinge bereinigt umso geringer der Aufwand.

p80286 19. Okt 2012 15:31

AW: Problem beim ändern von Datensätzen
 
Und was ist wenn du mit
Delphi-Quellcode:
.Parameters.Parambyname('mwateueralt').value:=irgendwas
arbeiten würdest?
Ggf. könnte man mit
Delphi-Quellcode:
].Parameters.Parambyname('mwateueralt').DataType
etwas nachhelfen?

Gruß
K-H

Captnemo 22. Okt 2012 07:34

AW: Problem beim ändern von Datensätzen
 
Also ich habe es jetzt mal mit festen Werten direkt im SQL-Statement probiert:

Code:
items SET mwstname='''+mwst+''', mwstsatz='+Floattostr(satz)+' where mandantGUID='''+GUIDToString(frm_main.MandantGuid)+''' and mwstname='''+cbb_von.Text+''' and bill=0
Und siehe da, es funktiert.
Danach habe ich es nochmal über die Paramter probiert, exakt so, wie es eben vorher nicht funktionierte. Und plötzlich geht es auch so.

Fazit, wenn mwstname in der where-Klausel ein Leerstring ist, kommt diese Fehlermeldung.
Ich frage mich jetzt grad nur warum?
Hat jemand eine Erklärung für mich?

Natürlich kann ich das Problem jetzt umgehen, in dem ich entwender einfach immer das SQL-Statement selbst zusammensetze, aber grundsätzlich denke ich, dass es doch auch anders gehen müßte.


Alle Zeitangaben in WEZ +1. Es ist jetzt 13:56 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