AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi GUID Parameterübergabe ADOQuery
Thema durchsuchen
Ansicht
Themen-Optionen

GUID Parameterübergabe ADOQuery

Ein Thema von WizoHulk · begonnen am 26. Jul 2011 · letzter Beitrag vom 26. Jul 2011
Antwort Antwort
WizoHulk

Registriert seit: 25. Jun 2010
198 Beiträge
 
Delphi 5 Enterprise
 
#1

GUID Parameterübergabe ADOQuery

  Alt 26. Jul 2011, 13:41
Datenbank: MS Server • Version: 2008 • Zugriff über: ADO
Hallo

ich hänge mal wieder ziemlich fest.

Ich führe ein SQL Update aus und übergebe die Werte mit Parametern.
Ein Wert ist eine Identifikationsnummer(GUID) die ich auch übergeben will.
Ist die Numnmer nicht Gesetzt kommt ein 'NULL' als string zurück was dann zu einen Fehler führt.

Kann man das irgendwie in der Query einstellen.

hier mal mein Code

Delphi-Quellcode:
CreateQuery(qtemp);
  qtemp.ParamCheck := true;
  qTemp.SQl.text := 'UPDATE AnalyseAkquiseConfig SET '+
                                       'Event = :Event, '              +
                                       'Betreff = :Betreff, '            +
                                       'TerminText = :TerminText, '        +
                                       'MitTyp = :MitTyp, '            +
                                       'IAkteAkquise = :IAkteAkquise, '      +
                                       'MitDSN = :MitDSN, '            +
                                       'KontaktTyp = :KontaktTyp, '        +
                                       'ProzessDSN = :ProzessDSN '        +
                                       'OnOwnEventNoCreate = :OnOwnEventNoCreate, '+
                                       'Gewichtung = :Gewichtung '         +
                    'WHERE DSN = '+alsDSN(sSatzDSN);
  //Parameterübergabe
  qtemp.Parameters.ParamByName('Event').Value := IntToStr(ZuAkqEvntNr(cbEvent.ItemIndex));
  qtemp.Parameters.ParamByName('Betreff').Value := eBetreff.Text;
  qtemp.Parameters.ParamByName('TerminText').Value := Bemerkungen.Text;
  qtemp.Parameters.ParamByName('MitTyp').Value := AlsZahl(IntToStr(cbMitarbeiter.ItemIndex));
  qtemp.Parameters.ParamByName('IAkteAkquise').Value := AlsZahl(IntToStr(cbAktion.ItemIndex));
  qtemp.Parameters.ParamByName('MitDSN').Value := '{B6625AD8-D894-4D25-BCBE-6A610E295903}';//AlsDSN(beMitarbeiter.DSN);


  qtemp.Parameters.ParamByName('KontaktTyp').LoadFromStream(sStream,ftBlob);
  qtemp.Parameters.ParamByName('ProzessDSN').Value := ProzessSQL;// Result := 'NULL' oder GUID
  qtemp.Parameters.ParamByName('OnOwnEventNoCreate').Value := BoolToStr(cbOnOwnEventNoCreate.Checked);
  qtemp.Parameters.ParamByName('Gewichtung').Value := AlsZahl(IntToStr(
                                                                                AkquiseBewertungZuInt(
                                                                                  TGewichtung(cbPrioritaet.ItemIndex),
                                                                                  TGewichtung(cbStorno.ItemIndex),
                                                                                  TGewichtung(cbAbschluss.ItemIndex),
                                                                                  TGewichtung(cbKundenbindg.ItemIndex),
                                                                                  TGewichtung(cbProv.ItemIndex),
                                                                                  TGewichtung(cbHaftung.ItemIndex))
                                                                                ));

  qTemp.ExecSQL;
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

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

AW: GUID Parameterübergabe ADOQuery

  Alt 26. Jul 2011, 14:50
Bist Du sicher, dass 'NULL' zurückkommt? Und wenn, was soll dann stattdessen eingetragen werden? Sind NULL-Werte in dem entsprechenden Feld erlaubt?
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 p80286
p80286

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

AW: GUID Parameterübergabe ADOQuery

  Alt 26. Jul 2011, 15:03
Ich habe da so meine Probleme den Fehler nach zu vollziehen.
wenn "ProzessDSN" als String(varchar/char....) definiert ist, dann sollte man von '',' ','NULL'' bis 'PillePalle' eigentlich alles übergeben können was einem in den Sinn komt.

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

Registriert seit: 25. Jun 2010
198 Beiträge
 
Delphi 5 Enterprise
 
#4

AW: GUID Parameterübergabe ADOQuery

  Alt 26. Jul 2011, 15:16
Die Spalte"ProzessDSN" ist mit uniqueidentifier gesetzt.
Wird jetzt 'NULL' gesetzt kommt der Fehler Falsche Convertierung.
Das Result von ProzessSQL ist string.
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

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

AW: GUID Parameterübergabe ADOQuery

  Alt 26. Jul 2011, 15:36
Wenn das Feld einen Default-Wert besitzt, könnte man evtl. abhängig davon, ob ProzessSQL eine GUID zurückgibt, unterschiedliche Statements implementieren (einmal mit und einmal ohne Angabe der GUID).
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 p80286
p80286

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

AW: GUID Parameterübergabe ADOQuery

  Alt 26. Jul 2011, 16:03
Wenn das Feld einen Default-Wert besitzt,
Ein UniqueIdentifier mit einem Default-Wert?
spätestens beim zweiten gleichen Eintrag sollte es krachen!?

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

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

AW: GUID Parameterübergabe ADOQuery

  Alt 26. Jul 2011, 16:47
Was ich meinte: http://msdn.microsoft.com/de-de/library/ms190215.aspx
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 p80286
p80286

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

AW: GUID Parameterübergabe ADOQuery

  Alt 26. Jul 2011, 16:54
Pardon, ein Mistverständnis!

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

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

AW: GUID Parameterübergabe ADOQuery

  Alt 26. Jul 2011, 16:58
Kein Thema, ich hatte mich auch missverständlich ausgedrückt
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
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 05:25 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