Ten samouczek powinien działać dla każdego pliku, a nie tylko Excela. Klucz jest w tej części:
Stream fs = FileUpload1.PostedFile.InputStream;
BinaryReader br = new BinaryReader(fs); //reads the binary files
Byte[] bytes = br.ReadBytes((Int32)fs.Length); //counting the file length into bytes
query = "insert into Excelfiledemo(Name,type,data)" + " values (@Name, @type, @Data)"; //insert query
com = new SqlCommand(query, con);
com.Parameters.Add("@Name", SqlDbType.VarChar).Value = filename1;
com.Parameters.Add("@type", SqlDbType.VarChar).Value = type;
com.Parameters.Add("@Data", SqlDbType.Binary).Value = bytes;
com.ExecuteNonQuery();
Label2.ForeColor = System.Drawing.Color.Green;
Label2.Text = "File Uploaded Successfully";
Zasadniczo dzieje się tutaj, że strumień plików jest przekształcany w tablicę Byte, która jest przechowywana jako blob danych w Twojej bazie danych. Może to być używane dla każdego typu pliku. Tylko pamiętaj, aby zachować nazwę pliku (lub przynajmniej rozszerzenie) tak, jak w powyższym przykładzie, aby wiedzieć, jaki to jest plik, gdy zmienisz go z powrotem na plik na dysku.