AGB  ·  Datenschutz  ·  Impressum  







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

SetBlobData bei ADOQuery

Ein Thema von HolgerCW · begonnen am 18. Dez 2014 · letzter Beitrag vom 7. Jan 2015
Antwort Antwort
HolgerCW

Registriert seit: 28. Nov 2006
Ort: Marl
1.207 Beiträge
 
Delphi XE7 Enterprise
 
#1

SetBlobData bei ADOQuery

  Alt 18. Dez 2014, 10:05
Datenbank: Oracle • Version: 10 • Zugriff über: BDE/ADO
Hallo zusammen,

stelle derzeit auf ADO um.

Vorher ging dies:

DM_Main.QueryRaw.ParamByName('p_pdf').SetBlobData(outstream.Memory, outstream.Size); Wie geht das bei ADOQuery ? Dort gibt es den Befehl "SetBlobData" an der Stelle nicht ? So geht es nicht:

DM_Main.ADOQueryRaw.Parameters.ParamByName('p_pdf').SetBlobData(outstream.Memory, outstream.Size); Gruss

Holger
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.624 Beiträge
 
Delphi 12 Athens
 
#2

AW: SetBlobData bei ADOQuery

  Alt 18. Dez 2014, 10:13
http://stackoverflow.com/questions/1...component-only
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
HolgerCW

Registriert seit: 28. Nov 2006
Ort: Marl
1.207 Beiträge
 
Delphi XE7 Enterprise
 
#3

AW: SetBlobData bei ADOQuery

  Alt 18. Dez 2014, 10:55
Vielen dank dafür.
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.196 Beiträge
 
Delphi 10.4 Sydney
 
#4

AW: SetBlobData bei ADOQuery

  Alt 18. Dez 2014, 11:19
Oracle und Ado? Du stellst - um es ketzerisch zu sagen - von der Pest auf Cholara um.
Für Oracle ist es besser auf native Komponenten umzustellen die oracle entweder direkt odet über den (Instant)Client ansprechen können. Ado ist hier ein (potentiell fehlerträchtiger) Fremdkörper.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
HolgerCW

Registriert seit: 28. Nov 2006
Ort: Marl
1.207 Beiträge
 
Delphi XE7 Enterprise
 
#5

AW: SetBlobData bei ADOQuery

  Alt 7. Jan 2015, 11:28
Hallo nochmal,

habe das nun testen können und es klappt leider nicht. Was mache ich falsch ?

Hier mal der Code, welcher einen Stream auslesen soll und anschliessend wieder an einer anderen Stelle einfügen soll:

Delphi-Quellcode:
var
 blob: TStream;
 outstream: TMemoryStream;
 Query: TADOQuery;
begin

 DM_Main.ADOTableRaw.Close;
 DM_Main.ADOTableRaw.TableName := 'KO_STATIONSTYP';
 DM_Main.ADOTableRaw.IndexFieldNames := 'STATIONSTYP';
 DM_Main.ADOTableRaw.Filter := 'STATIONSTYP = ''' + DM_KSB.ADOQueryBestellung['STATIONSTYP'] + '''';
 DM_Main.ADOTableRaw.Filtered := TRUE;
 DM_Main.ADOTableRaw.Open;

 if DM_Main.ADOTableRaw['BEDIENUNGSANLEITUNG'] <> 'then
 begin

  blob := DM_Main.ADOTableRaw.CreateBlobStream(DM_Main.ADOTableRaw.FieldByName('BEDIENUNGSANLEITUNG'), bmRead);
  blob.Seek(0, soFromBeginning);

  outstream := TMemoryStream.Create;
  outstream.LoadFromStream(blob);
  outstream.Seek(0, soFromBeginning);

  DM_Main.ADOQueryRaw.Close;
  DM_Main.ADOQueryRaw.SQL[1] := 'SYSFORM.KOBUSYS_VERLAUF';
  DM_Main.ADOQueryRaw.SQL[3] := 'BEDIENUNGSANLEITUNG';
  DM_Main.ADOQueryRaw.SQL[5] := 'WHERE ID';
  //DM_Main.QueryRaw.ParamByName('p_pdf').SetBlobData(outstream.Memory, outstream.Size);
  DM_Main.ADOQueryRaw.Parameters.ParamByName('p_pdf').LoadFromStream(outstream.Memory, ftBlob);
  DM_Main.ADOQueryRaw.Parameters.ParamByName('p_auftragsnummer').Value := inttostr(DM_KSB.ADOQueryBestellung['ID']);
  DM_Main.ADOQueryRaw.ExecSQL;

  outstream.Free;

  blob.Free;

 end;
und hier noch der SQL-Code der Query:

Delphi-Quellcode:
UPDATE
SYSDBP.DBP_AUFTRAGEX
SET
PDF
= :p_pdf
WHERE AUFTRAGSNUMMER
= :p_auftragsnummer
Bei .LoadFromStream kommt der Fehler "Zugriffsverletzung bei Adresse ...". Das Auskommentierte ist der vorherige Code mit der BDE und TQuery. Das ging. Nun will ich das ja mit ADOQuery machen.

Vielleicht kennt Ihr ja auch eine ganz andere Lösung für das kopieren von einem Stream ...

Gruss

Holger

Geändert von HolgerCW ( 7. Jan 2015 um 11:33 Uhr)
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: SetBlobData bei ADOQuery

  Alt 7. Jan 2015, 12:31
Di Du solltest nicht die selbe Komponenet nehmen. Zum Zeitpunkt des Einfügens existiert der Blob ja nicht mehr.
Markus Kinzler
  Mit Zitat antworten Zitat
HolgerCW

Registriert seit: 28. Nov 2006
Ort: Marl
1.207 Beiträge
 
Delphi XE7 Enterprise
 
#7

AW: SetBlobData bei ADOQuery

  Alt 7. Jan 2015, 12:37
Warum existiert er da nicht mehr. Oben das ist ein Table und unten eine Query oder was meinst Du ?
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: SetBlobData bei ADOQuery

  Alt 7. Jan 2015, 12:40
Der programmseitige Zugriff ist gekappt.
Markus Kinzler
  Mit Zitat antworten Zitat
HolgerCW

Registriert seit: 28. Nov 2006
Ort: Marl
1.207 Beiträge
 
Delphi XE7 Enterprise
 
#9

AW: SetBlobData bei ADOQuery

  Alt 7. Jan 2015, 12:48
Hi,

habe nun schon mal die Fehlermeldung beseitigt. Folgender Code:

DM_Main.ADOQueryRaw.Parameters.ParamByName('p_pdf').LoadFromStream(outstream.Memory, ftBlob); war falsch. Das "outstream.Memory" darf nur "outstream" heissen.

Du hast aber recht. Er fügt nichts ein. An welcher Stelle des codes mache ich was falsch. Verstehe das noch nicht so ganz ?
  Mit Zitat antworten Zitat
HolgerCW

Registriert seit: 28. Nov 2006
Ort: Marl
1.207 Beiträge
 
Delphi XE7 Enterprise
 
#10

AW: SetBlobData bei ADOQuery

  Alt 7. Jan 2015, 13:02
Habe mich vertan. Er macht nun das was er soll. Alles funktioniert wunderbar. Ausser das auslesen dauert gefühlsmässig länger als noch mit der BDE.

Gruss

Holger
  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 13:53 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