PDFtoolkit VCL
Edit, enhance, secure, merge, split, view, print PDF and AcroForms documents
Compatibility
Delphi C++Builder

How To Save a PDF Document To A Database

“I want to save a PDF document to a BLOB (Binary Large Object) field.”
By Suraj C. B.

TBlobStream is used to read or write to a BLOB field in a dataset. If you can write a PDF document to a BLOB field, then you can store the PDF document in an RDBMS database.

PDFtoolkit allows you to save a PDF document to a memory stream. You can then use the memory stream to copy the PDF document to a TBlobStream instance. The code snippet below shows you how.

procedure TForm1.SavetoBlobClick(Sender: TObject);
 var
   blob: TBlobStream;
   TempStrm: TMemoryStream;
 begin
  // Create a blob stream for writing 
  blob := YourDataset.CreateBlobStream(
               YourDataset.FieldByName('YOUR_BLOB_FIELD_NAME'),
               bmWrite);
   try
     // Move to the beginning of the blob stream for read operations
     blob.Seek(0, soFromBeginning);
     // Create a memory stream
     TempStrm := TMemoryStream.Create;
     // Load a PDF document
     gtPDFDocument1.LoadFromFile('C:\Input.pdf');

     // Steps for modifying the PDF omitted.

     // Save the PDF document to the stream 
     gtPDFDocument1.SaveToStream(TempStrm);

     // Move to the beginning of the memory stream for read operations
     TempStrm.Position := 0;
     // Copy the stream to the blob
     try
       blob.CopyFrom(TempStrm, TempStrm.Size)
     finally
       TempStrm.Free
     end;
   finally
     blob.Free
   end;
end;
Privacy | Legal | Feedback | Newsletter © 2002-2010 Gnostice Information Technologies Private Limited. All rights reserved.

This site is best viewed on a screen with minimum resolution of 1152 x 864 pixels. Windows users are advised to use Microsoft ClearType Tuning for optimal experience. Linux and other users can enable font smoothing, as supported by their OS. Also, please use the latest version of a standards-compliant browser such as Opera, FireFox, Chrome or Safari.