![]() |
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:
In meine Code hab ich:
Update items SET mwstname=:mwstnameneu, mwstsatz=:mwstsatz where
mandantGUID=:mandantGUID and mwstname=:mwstnamealt and bill=0
Delphi-Quellcode:
Und bekomme folgende Fehlermeldung
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; Zitat:
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? |
AW: Problem beim ändern von Datensätzen
Und bill?
|
AW: Problem beim ändern von Datensätzen
Wow, bist du fix. :-)
Sorry, hab ich vergessen. Bill = Integer; |
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:
, aber vielleicht hast du ja in der falschen Datenbank nachgeschaut.
mwstname = varchar(200)
PS: Du solltest die Tabelle nicht "Items" nennen. Suche dir einen ausagekräftigen Namen. |
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. |
AW: Problem beim ändern von Datensätzen
Zitat:
Ich glaube nicht, dass das Feld "Kommentar" die Ursache der Probleme ist. Zitat:
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:
|
AW: Problem beim ändern von Datensätzen
Und was ist wenn du mit
Delphi-Quellcode:
arbeiten würdest?
.Parameters.Parambyname('mwateueralt').value:=irgendwas
Ggf. könnte man mit
Delphi-Quellcode:
etwas nachhelfen?
].Parameters.Parambyname('mwateueralt').DataType
Gruß K-H |
AW: Problem beim ändern von Datensätzen
Also ich habe es jetzt mal mit festen Werten direkt im SQL-Statement probiert:
Code:
Und siehe da, es funktiert.
items SET mwstname='''+mwst+''', mwstsatz='+Floattostr(satz)+' where mandantGUID='''+GUIDToString(frm_main.MandantGuid)+''' and mwstname='''+cbb_von.Text+''' and bill=0
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 02:07 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