tags:

views:

54

answers:

2

Dear All,

I have a requirement and that is as follows:

Aussume that i have a windows form in which i type all the details of an employee and i need to attach his resume [ which is in a PDF Format] to his details. When i click the save button, all his details which he has entered can be stored into a table.

Now what i really want is that:

1.How do i attach a PDF file into the windows form which the user can do by clicking a button after typing all his details.

  1. When the user clicks the save button, how do i save the file that has been attached by the user.

  2. When i retrieve the employee details, i want the file which was attached also to be displayed and shown.

Request anyone to please help on this.

Regards, George

+2  A: 

Use the OpenFileDialog to allow the user to browse to the PDF they want to attach. Store the file path of the selected PDF.

When the user saves the record, read the file the user selected into a byte[], and save that byte[] into a database field (probably a blob field). (See here)

To read it back in, do the reverse. Get the byte[] out of the database, and reassemble it into a file, save the file as a temp PDF and then start a process to load it. (See here)

Michael Shimmins
A: 

Here's a simple example, with no error checking, demonstrating Michael Shimmins' good suggestion.

Dim ofd As New OpenFileDialog()
'Set ofd settings'
If ofd.ShowDialog() = DialogResult.Cancel Then
    Return
End If
Dim pdfData As Byte() = File.ReadAllBytes(ofd.FileName)
'Save it to your database.'

However, I suggest you consider copying the files to a file server instead of dealing with the binary data and BLOBs if you can help it. BLOBs have been known to kill database performance on some platforms. Here's one reference. Google "blob database performance" for more.

Here's an example of copying the file to a file server.

Dim newFileName As String = UniqueFileNameGeneratingFunction()
File.Copy(odf.FileName, newFileName)
'Save newFileName to your database as a string, and retrieve the file as needed'
'from the file server'
John M Gant
Only issue would be if its a distributed system - you'd need to save to a network path, which can get complicated as well.
Michael Shimmins