Solved

DBGrid/TField and memofields

Posted on 1997-08-14
4
319 Views
Last Modified: 2010-04-06
Hi

I'm trying to print/display memofields from a DBGrid, but I just seem to get stuck whatever I do to read the memofield.

I the DBGrid (wwDBGrid) to display columns from SQL-statements (which the
end-user defines) and would then like to print the grid. I've only got a
problem with the memofields-columns (which displays just displays "(Memo)").

Is this the correct way to do it? And what do I need to display/print the memofield?

   if Fields[FieldNo].DataType = ftMemo then
   begin
     with Fields[FieldNo] do
     begin
       GetMem(TheField, Datasize);   { Allocate space }
       if GetData(TheField) then
       begin

          how do I use the "TheField"?
          how can I extract the data?


       end;
       FreeMem(TheField,DataSize);
     end;
   end;

I just think I have tried every possible way to extract the data from
"TheField", but I still haven't got the hang of it.

Can you please help me?

Jakob Hoffmann

0
Comment
Question by:alijakob
4 Comments
 

Expert Comment

by:hkelmer
ID: 1341426
why don´t you use InfoPower or DBpower or any other vcl that
has this special dbgrid with memos?
just check their demo´s

0
 
LVL 1

Expert Comment

by:Zonnald
ID: 1341427
alijakob,

I have a better ***Free*** solution but really could use the points - depending on the size of the MEMO field's data.

Please assess hkelmer's answer if you will.

Zonnald
0
 

Author Comment

by:alijakob
ID: 1341428
Hello

I have checked the InfoPower demos - there's no information about processing the contents of memofields.

My application is based on the InfoPower wwDBGrids where I do use the facility to display memofields. Using the wwDBGrids, it's not possible to print/use the contents of the memofields directly.

I have however, found a solution to my problems which seems to work - it'll only show the first 255 characters of the memofield (but the whole string is there!):

FieldSize   : LongInt;      { Will hold the fieldsize }
bstTheField : TBlobStream;  { The connection between us and the memofield }
TheField    : PChar;        { Will hold the contents read from the memofield }

bstTheField := TBlobStream.Create((Fields[FieldNo] as TMemoField),bmRead);
FieldSize   := bstTheField.Seek(0,2);  { Go to end of memofield to find size }
GetMem(TheField,FieldSize + 1);  { Allocate memory for contents }
if (TheField = nil) then raise Exception.Create('Not enough memory');
bstTheField.Seek(0,0);  { Go to start of field before reading contents }
FillChar(TheField^,FieldSize + 1,#0);  { Initialize the string }
bstTheField.Read(TheField^,FieldSize);  { Read contents of field }
showmessage('memo='+strpas(TheField)); {only shows the first 255 characters}

Jakob
0
 
LVL 2

Accepted Solution

by:
icampbe1 earned 50 total points
ID: 1341429
I'm gonna step out on a limb here and hope that this is a sensible answer.  I am using a DBCntrlGrid very successfully for this purpose.  It is a very good solution.

The DBCtrlGrid lets to put compnents of your own choice on every 'record' of the dataset.  This includes a DBMemo component.  It kind of like designing your own little form for each record.  It is very slick and I find the result look better than a plain DBGrid.

Hope this is acceptable,

Ian C.
0

Featured Post

Netscaler Common Configuration How To guides

If you use NetScaler you will want to see these guides. The NetScaler How To Guides show administrators how to get NetScaler up and configured by providing instructions for common scenarios and some not so common ones.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Creating an auto free TStringList The TStringList is a basic and frequently used object in Delphi. On many occasions, you may want to create a temporary list, process some items in the list and be done with the list. In such cases, you have to…
Hello everybody This Article will show you how to validate number with TEdit control, What's the TEdit control? TEdit is a standard Windows edit control on a form, it allows to user to write, read and copy/paste single line of text. Usua…
This Micro Tutorial will teach you how to censor certain areas of your screen. The example in this video will show a little boy's face being blurred. This will be demonstrated using Adobe Premiere Pro CS6.
A short tutorial showing how to set up an email signature in Outlook on the Web (previously known as OWA). For free email signatures designs, visit https://www.mail-signatures.com/articles/signature-templates/?sts=6651 If you want to manage em…

825 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question