Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Saving any file to in the database, just convert it to a byte array?

Tags:

c#

file-io

byte

Is converting a file to a byte array the best way to save ANY file format to disk or database var binary column?

So if someone wants to save a .gif or .doc/.docx or .pdf file, can I just convert it to a bytearray UFT8 and save it to the db as a stream of bytes?

like image 775
Blankman Avatar asked Apr 05 '10 15:04

Blankman


People also ask

How do I save a byte file?

Java – How to save byte[] to a filewrite is the simplest solution to save byte[] to a file. // bytes = byte[] Path path = Paths. get("/path/file"); Files. write(path, bytes);

Can you store a byte array in SQL?

In Sql Server, use image data type or varbinary data type, to store byte array data.


1 Answers

Since it's not mentioned what database you mean I'm assuming SQL Server. Below solution works for both 2005 and 2008.

You have to create table with VARBINARY(MAX) as one of the columns. In my example I've created Table Raporty with column RaportPlik being VARBINARY(MAX) column.

Method to put file into database from drive:

public static void databaseFilePut(string varFilePath) {     byte[] file;     using (var stream = new FileStream(varFilePath, FileMode.Open, FileAccess.Read)) {         using (var reader = new BinaryReader(stream)) {             file = reader.ReadBytes((int) stream.Length);                }               }     using (var varConnection = Locale.sqlConnectOneTime(Locale.sqlDataConnectionDetails))     using (var sqlWrite = new SqlCommand("INSERT INTO Raporty (RaportPlik) Values(@File)", varConnection)) {         sqlWrite.Parameters.Add("@File", SqlDbType.VarBinary, file.Length).Value = file;         sqlWrite.ExecuteNonQuery();     } } 

This method is to get file from database and save it on drive:

public static void databaseFileRead(string varID, string varPathToNewLocation) {     using (var varConnection = Locale.sqlConnectOneTime(Locale.sqlDataConnectionDetails))     using (var sqlQuery = new SqlCommand(@"SELECT [RaportPlik] FROM [dbo].[Raporty] WHERE [RaportID] = @varID", varConnection)) {         sqlQuery.Parameters.AddWithValue("@varID", varID);         using (var sqlQueryResult = sqlQuery.ExecuteReader())             if (sqlQueryResult != null) {                 sqlQueryResult.Read();                 var blob = new Byte[(sqlQueryResult.GetBytes(0, 0, null, 0, int.MaxValue))];                 sqlQueryResult.GetBytes(0, 0, blob, 0, blob.Length);                 using (var fs = new FileStream(varPathToNewLocation, FileMode.Create, FileAccess.Write))                      fs.Write(blob, 0, blob.Length);             }     } } 

This method is to get file from database and put it as MemoryStream:

public static MemoryStream databaseFileRead(string varID) {     MemoryStream memoryStream = new MemoryStream();     using (var varConnection = Locale.sqlConnectOneTime(Locale.sqlDataConnectionDetails))     using (var sqlQuery = new SqlCommand(@"SELECT [RaportPlik] FROM [dbo].[Raporty] WHERE [RaportID] = @varID", varConnection)) {         sqlQuery.Parameters.AddWithValue("@varID", varID);         using (var sqlQueryResult = sqlQuery.ExecuteReader())             if (sqlQueryResult != null) {                 sqlQueryResult.Read();                 var blob = new Byte[(sqlQueryResult.GetBytes(0, 0, null, 0, int.MaxValue))];                 sqlQueryResult.GetBytes(0, 0, blob, 0, blob.Length);                 //using (var fs = new MemoryStream(memoryStream, FileMode.Create, FileAccess.Write)) {                 memoryStream.Write(blob, 0, blob.Length);                 //}             }     }     return memoryStream; } 

This method is to put MemoryStream into database:

public static int databaseFilePut(MemoryStream fileToPut) {         int varID = 0;         byte[] file = fileToPut.ToArray();         const string preparedCommand = @"                     INSERT INTO [dbo].[Raporty]                                ([RaportPlik])                          VALUES                                (@File)                         SELECT [RaportID] FROM [dbo].[Raporty]             WHERE [RaportID] = SCOPE_IDENTITY()                     ";         using (var varConnection = Locale.sqlConnectOneTime(Locale.sqlDataConnectionDetails))         using (var sqlWrite = new SqlCommand(preparedCommand, varConnection)) {             sqlWrite.Parameters.Add("@File", SqlDbType.VarBinary, file.Length).Value = file;              using (var sqlWriteQuery = sqlWrite.ExecuteReader())                 while (sqlWriteQuery != null && sqlWriteQuery.Read()) {                     varID = sqlWriteQuery["RaportID"] is int ? (int) sqlWriteQuery["RaportID"] : 0;                 }         }         return varID;     } 
like image 61
MadBoy Avatar answered Oct 15 '22 00:10

MadBoy