AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Netzwerke C# Webservice Datei als Parameter
Thema durchsuchen
Ansicht
Themen-Optionen

Webservice Datei als Parameter

Ein Thema von Maa83 · begonnen am 20. Feb 2008 · letzter Beitrag vom 21. Feb 2008
Antwort Antwort
Maa83

Registriert seit: 7. Nov 2002
220 Beiträge
 
Delphi 10.3 Rio
 
#1

Webservice Datei als Parameter

  Alt 20. Feb 2008, 12:12
Hallo,

ich hoffe ihr könnt mir helfen:

Ich habe eine Methode in einem Webservice. Die Methode hat mehrere "normale" Parameter (also String, Integer) und einen Parameter PDFFile. In diesem soll eine komplette PDF-Datei übergeben werden (also nicht nur der Pfad). Die Übergebenen Paramter werden samt der Datei in eine Datenbank-Tabelle geschrieben.

Versucht habe ich folgendes:

Der Paramter vom Typ "Byte[] PDFDatei".

Beim Einfügen in die Datenbank:

sSQL = "INSERT INTO TABELLE (SPALTE1, SPALTE2, PDFDATEI) VALUES ('123','ichunddu','@PDFDATEI')";
ad.SelectCommand.Parameters.Add("@PDFDATEI", SqlDbType.Image).Value = PDFDatei; //PDFDatei vom Typ Byte[]

ds.Clear();
ad.SelectCommand.CommandText = sSQL;
ad.Fill(ds);

//ad = SqlDataAdapter
//ds = DataSet

Das klappt aber so alles nicht.
Martin
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Webservice Datei als Parameter

  Alt 20. Feb 2008, 12:16
Wird ein Fehler angezeigt?
Sollte es nicht
Code:
ad.SelectCommand.Parameters.Add("PDFDATEI", SqlDbType.Image).Value = PDFDatei;
heißen?
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von Jelly
Jelly

Registriert seit: 11. Apr 2003
Ort: Moestroff (Luxemburg)
3.741 Beiträge
 
Delphi 2007 Professional
 
#3

Re: Webservice Datei als Parameter

  Alt 20. Feb 2008, 12:23
Zitat von Maa83:
Code:
sSQL = "INSERT INTO TABELLE (SPALTE1, SPALTE2, PDFDATEI) VALUES ('123','ichunddu','@PDFDATEI')";
ad.SelectCommand.Parameters.Add("@PDFDATEI", SqlDbType.Image).Value = PDFDatei; //PDFDatei vom Typ Byte[]
Lassmal die Quotes um '@PDFDatei' weg.
  Mit Zitat antworten Zitat
Maa83

Registriert seit: 7. Nov 2002
220 Beiträge
 
Delphi 10.3 Rio
 
#4

Re: Webservice Datei als Parameter

  Alt 20. Feb 2008, 12:54
Zitat von mkinzler:
Sollte es nicht
Code:
ad.SelectCommand.Parameters.Add("PDFDATEI", SqlDbType.Image).Value = PDFDatei;
heißen?
Das probier ich gleich mal aus.


Die Quotes sind in meinem eigentlichen Code gar nicht da, sorry
Martin
  Mit Zitat antworten Zitat
Maa83

Registriert seit: 7. Nov 2002
220 Beiträge
 
Delphi 10.3 Rio
 
#5

Re: Webservice Datei als Parameter

  Alt 21. Feb 2008, 09:18
hat leider auch nicht funktioniert. Es kommt komischerweise immer ein INSERT-Fehler.

"Server was unable to process request. ---> In der INSERT-Anweisung sind
weniger Spalten angegeben als Werte in der VALUES-Klausel. Die Anzahl
von Werten in der VALUES-Klausel und die Anzahl von in der
INSERT-Anweisung angegebenen Spalten mÃŒssen
ÃŒbereinstimmen."

Die Insert-Anweisung ist aber richtig da es ohne PDF-File (mit NULL) funktioniert.

Daher muss es irgendwie mit dem byte[]-Datentyp oder mit dem .Parameters.Add("PDFDATEI", SqlDbType.Image).Value = PDFDatei; zu tun haben.


Nebenfrage:
Wie initialisiere ich denn einen byte[]-Datentyp richtig?
Welchen Wert hat ein byte[]-Datentyp wenn er die Länge 0 besitzt?
Martin
  Mit Zitat antworten Zitat
Benutzerbild von Jelly
Jelly

Registriert seit: 11. Apr 2003
Ort: Moestroff (Luxemburg)
3.741 Beiträge
 
Delphi 2007 Professional
 
#6

Re: Webservice Datei als Parameter

  Alt 21. Feb 2008, 11:24
Ich weiss nicht ob das mit der direkten Insert Anweisung so klappt mit den Blobfeldern.

Probier eventuell mal folgendes:
select * from Tabelle where 1=2

öffne dein Dataset und nutze dann die Insert-Methode vom Dataset, um einen neuen Record anzulegen, den du, nach setzen der Felder, mit Post dann wegschreibst.
  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 17:15 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