Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2004.08.29;
Скачать: CL | DM;

Вниз

Проблема с записью в BLOB-поле   Найти похожие ветки 

 
Zabludshiy   (2004-08-05 17:19) [0]

Доброго всем времени. Oracle8i, Delphi-6. К базе подключаюсь с помощю ODAC.
Пытаюсь записать RichEdit в CLOB следующим образом:

procedure TNewDocVizard.Button11Click(Sender: TObject);
var FullDocText:string;
   BlobStream:tStream;
begin
     SmartQuery1.Active:=False;
     SmartQuery1.ParamByName("Cond").AsInteger:=465;
     SmartQuery1.Open;
     if SmartQuery1.State = dsBrowse then
       SmartQuery1.Edit;
     BlobStream:=SmartQuery1.CreateBlobStream(SmartQuery1.FieldByName("doc_text"),bmWrite);
     Try
       BlobStream.Seek(0, soFromEnd);
       BlobStream.Write(pChar(RichEdit1.Text)^,length(RichEdit1.Text));
//      BlobStream.WriteBuffer();
       SmartQuery1.Post;
       DMod1.OracleSession1.Commit;
     Finally
       BlobStream.Free;
       SmartQuery1.Close;
     end;
end;

В результате в "doc_text" ничего не записывается (CLOB пустой), ошибок не выдаёт. 2-й день не могу понять где допустил ошибку?
Заранее спасибо за помощ.


 
Zabludshiy   (2004-08-05 17:22) [1]

В SmartQuery.sql такой запрос:
Select DIC.DOC_TEXT, DIC.RowId
from DIC
where COND = :Cond


 
Johnmen ©   (2004-08-05 17:49) [2]

>BlobStream.Write(pChar(RichEdit1.Text)^,length(RichEdit1.Text));

Видимо, либо
s:=RichEdit1.Text;
BlobStream.Write(pChar(s)^,length(s));

либо
BlobStream.Write(RichEdit1.Text[1],length(RichEdit1.Text));


 
Zabludshiy   (2004-08-05 18:12) [3]


> Johnmen ©   (05.08.04 17:49) [2]

Спасибо, но не помогло.

Что интересно, в новом (чистом) проекте на тестовой базе аналогичный код работает. Да и взят он из реально рабочего примера, одного из тех что шёл с ODAC.

Рабочий код, на нажатие кнопки:

begin
 if SmartQuery1.State = dsBrowse then
   SmartQuery1.Edit;
 BlobStream:=SmartQuery1.CreateBlobStream(SmartQuery1.FieldByName("tclob"),bmReadWrite);
 try
   BlobStream.Seek(0, soFromEnd);
   BlobStream.Write(PChar(memo1.Text)^,length(memo1.Text));
   SmartQuery1.Post;
 finally
   BlobStream.Free;
 end;
end;

А то что я модифицировал - никак не хочет работать.


 
Johnmen ©   (2004-08-05 18:19) [4]

А-а.. Понятно
глянь  TBlobStreamMode+F1


 
Zabludshiy   (2004-08-05 19:17) [5]

Да, действительно.
Спасибо.



Страницы: 1 вся ветка

Текущий архив: 2004.08.29;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.024 c
14-1091338374
ИМХО
2004-08-01 09:32
2004.08.29
Cartoon Network


14-1092138667
Sergey13
2004-08-10 15:51
2004.08.29
Книга Туркменбаши - смешно, ели б не так грустно


1-1092293939
Anton777
2004-08-12 10:58
2004.08.29
Точки


6-1086981860
Dimaxx
2004-06-11 23:24
2004.08.29
Скачивание файлов с использованием wininet


1-1092417058
Gnec
2004-08-13 21:10
2004.08.29
Как сделать перескок к нужному итему?