Solved

Help with managing files in a database, using TADOTable and TDataSource.

Posted on 2004-09-08
9
279 Views
Last Modified: 2013-12-03
I'm using Delphi 7, and i am writing a mail client.
I need an example code, showing how to manage files in a MS Access Database, using those two components.
What do i need to use? May be an OLE Object?
0
Comment
Question by:bbh2k3
  • 3
  • 2
  • 2
  • +2
9 Comments
 
LVL 17

Expert Comment

by:Wim ten Brink
ID: 12004989
How do you want to do that? What do you mean by managing files? If you want to store emails in your database, then store them in their raw format, which happens to be ANSI-text. Also, use a TADOQuery instead since it offers a better performance.
0
 
LVL 17

Expert Comment

by:geobul
ID: 12005010
Hi,

Perhaps you are talking about managing tables not files. If so, what kind of management you are interested in? Be more specific please.

Regards, Geo
0
 
LVL 27

Expert Comment

by:kretzschmar
ID: 12005228
nothing to append ...  waiting for further info
0
 
LVL 26

Expert Comment

by:EddieShipman
ID: 12010297
I would think he means file attachments and how to post them to an Access database blob field.
0
Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

 
LVL 17

Expert Comment

by:Wim ten Brink
ID: 12014466
Well, even file attachments are part of the raw email. They're just encoded as strings. All you need is a memo field... (Unless you're not retrieving emails in their raw format.)
0
 
LVL 26

Expert Comment

by:EddieShipman
ID: 12016217
Maybe he is decoding them and wants the capability to save the decoded file?

So bbh2k3, would you please enlighten us on your requirements?
0
 

Author Comment

by:bbh2k3
ID: 12035547
I want to store the email as ANSI text, i want to know how to store the attachment in a blob field, and extract it later.
0
 
LVL 17

Accepted Solution

by:
geobul earned 500 total points
ID: 12038477
Hi,

The example below uses files from disk and a table with one OLE Object field named 'filebin'.

// adds one file to the table
procedure TForm1.btnSaveClick(Sender: TObject);
begin
  if OpenDialog1.Execute then begin
    with ADOTable1 do begin
      Open;
      Append;
      FieldByName('id').AsString := Edit1.Text; // id - string
      FieldByName('filename').AsString := OpenDialog1.Filename; // original filename - string
      TBlobFIeld(FieldByName('filebin')).LoadFromFile(OpenDialog1.Filename); // the content of the file
      Post;
      Close;
      ShowMessage('Done');
    end;
  end;
end;

// extracts the first file to disk
procedure TForm1.btnGetClick(Sender: TObject);
var
  s: string;
begin
  if SaveDialog1.Execute then begin
    s := Edit1.Text;
    with ADOTable1 do begin
      Open;
      First; // you'll have to replace this line with Locate or similar method for finding thhe record of interest
      TBlobFIeld(FieldByName('filebin')).SaveToFile(SaveDialog1.Filename);
      ShowMessage('Done');
      Close;
    end;
  end;
end;

The example doesn't contain errors handling at all.

Regards, Geo
0
 
LVL 17

Expert Comment

by:geobul
ID: 12038516
If you also want to remove the file from the table use:

TBlobFIeld(ADOTable1.FieldByName('filebin')).Clear;

but in that case it would be necessary to check if that field is empty before saving it to a file this way:

if not ADOTable1.FieldByName('filebin').IsNull then ...

Hope this will help you.

Best regards, Geo
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

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

Suggested Solutions

Title # Comments Views Activity
ddeman not working in activex 3 92
Intraweb download file link ? 1 105
PowerPoint not providing access to all installed fonts within a family 22 229
erros on link  checking 2 60
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…
Introduction I have seen many questions in this Delphi topic area where queries in threads are needed or suggested. I know bumped into a similar need. This article will address some of the concepts when dealing with a multithreaded delphi database…
Excel styles will make formatting consistent and let you apply and change formatting faster. In this tutorial, you'll learn how to use Excel's built-in styles, how to modify styles, and how to create your own. You'll also learn how to use your custo…
Concerto provides fully managed cloud services and the expertise to provide an easy and reliable route to the cloud. Our best-in-class solutions help you address the toughest IT challenges, find new efficiencies and deliver the best application expe…

932 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

Need Help in Real-Time?

Connect with top rated Experts

16 Experts available now in Live!

Get 1:1 Help Now