AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Problem beim ändern von Datensätzen
Thema durchsuchen
Ansicht
Themen-Optionen

Problem beim ändern von Datensätzen

Ein Thema von Captnemo · begonnen am 19. Okt 2012 · letzter Beitrag vom 22. Okt 2012
Antwort Antwort
Benutzerbild von Captnemo
Captnemo

Registriert seit: 27. Jan 2003
Ort: Bodenwerder
1.126 Beiträge
 
Delphi XE4 Architect
 
#1

Problem beim ändern von Datensätzen

  Alt 19. Okt 2012, 15:00
Datenbank: MSSQL Express Edition • Version: 2005 • Zugriff über: ADO
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?
Dieter
9 von 10 Stimmen in meinem Kopf sagen ich bin nicht verrückt. Die 10. summt dazu die Melodie von Supermario Bros.
MfG Captnemo
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: Problem beim ändern von Datensätzen

  Alt 19. Okt 2012, 15:03
Und bill?
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von Captnemo
Captnemo

Registriert seit: 27. Jan 2003
Ort: Bodenwerder
1.126 Beiträge
 
Delphi XE4 Architect
 
#3

AW: Problem beim ändern von Datensätzen

  Alt 19. Okt 2012, 15:04
Wow, bist du fix.

Sorry, hab ich vergessen.

Bill = Integer;
Dieter
9 von 10 Stimmen in meinem Kopf sagen ich bin nicht verrückt. Die 10. summt dazu die Melodie von Supermario Bros.
MfG Captnemo
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#4

AW: Problem beim ändern von Datensätzen

  Alt 19. Okt 2012, 15:48
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.
Andreas
  Mit Zitat antworten Zitat
Benutzerbild von Captnemo
Captnemo

Registriert seit: 27. Jan 2003
Ort: Bodenwerder
1.126 Beiträge
 
Delphi XE4 Architect
 
#5

AW: Problem beim ändern von Datensätzen

  Alt 19. Okt 2012, 16:03
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.
Dieter
9 von 10 Stimmen in meinem Kopf sagen ich bin nicht verrückt. Die 10. summt dazu die Melodie von Supermario Bros.
MfG Captnemo
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#6

AW: Problem beim ändern von Datensätzen

  Alt 19. Okt 2012, 16:19
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.
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;
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.
Andreas
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

Registriert seit: 28. Apr 2008
Ort: Stolberg (Rhl)
6.659 Beiträge
 
FreePascal / Lazarus
 
#7

AW: Problem beim ändern von Datensätzen

  Alt 19. Okt 2012, 16:31
Und was ist wenn du mit
.Parameters.Parambyname('mwateueralt').value:=irgendwas arbeiten würdest?
Ggf. könnte man mit
].Parameters.Parambyname('mwateueralt').DataType etwas nachhelfen?

Gruß
K-H
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  Mit Zitat antworten Zitat
Benutzerbild von Captnemo
Captnemo

Registriert seit: 27. Jan 2003
Ort: Bodenwerder
1.126 Beiträge
 
Delphi XE4 Architect
 
#8

AW: Problem beim ändern von Datensätzen

  Alt 22. Okt 2012, 08:34
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.
Dieter
9 von 10 Stimmen in meinem Kopf sagen ich bin nicht verrückt. Die 10. summt dazu die Melodie von Supermario Bros.
MfG Captnemo
  Mit Zitat antworten Zitat
Antwort Antwort


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 00:28 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