有時由於某種需要(如安全性)須將圖片或文件存放在資料庫中,當然一般情況下特別是文件比較大的時候很多人不提倡將文件以二進制的形式存放在數據庫中的,現將Oracle中檔案的存取整理如下(想法和在SQL Server2000中存取一樣,儲存時在資料中存放圖片或檔案的二進位位元組流,讀出時將資料庫中對應欄位讀取到位元組數據,然後輸出):
1.在TOAD或SQLPlus中建立一下資料庫表。
1CREATE TABLE TEST_TABLE
2(
3 ID VARCHAR2(36 BYTE),
4 NAME VARCHAR2(50 BYTE),
5 PHOTO BLOB
6)
7
2.新建一個ASPX頁面,在頁面上放一個FileUpload控件,命名為fileUp,放置兩個按鈕分佈為btnSave(儲存),btnRead(讀取)。
3.在btnSave的事件中執行一下程式碼,用來保存圖片或檔案:
儲存圖片(檔案)到Oracle
1StringBuilder sbSQL = new StringBuilder("insert into Test_Table(ID,Name,Photo) values(:ID,:Name,:Photo)");
2 OracleConnection cn = new OracleConnection(strCn);
3 OracleCommand cmd = cn.CreateCommand();
4 cmd.CommandText = sbSQL.ToString();
5 cmd.Parameters.Add(":ID", OracleType.VarChar, 36).Value = Guid.NewGuid().ToString();
6 cmd.Parameters.Add(":Name", OracleType.VarChar, 50).Value = fileUp.FileName; ;
7 int intLen = fileUp.PostedFile.ContentLength;
8 byte[] pic = new byte[intLen];
9 fileUp.PostedFile.InputStream.Read(pic, 0, intLen);
10 cmd.Parameters.Add(":Photo", OracleType.Blob).Value = pic;
11 try
12 {
13 cn.Open();
14 cmd.ExecuteNonQuery();
15 }
16 catch (Exception ex)
17 {
18 Response.Write(ex.Message);
19 }
20 finally
21 {
22 cn.Close();
23 }
24
4、讀取方法如下:
從Oracle讀取圖片(檔案)
1OracleConnection cn = new OracleConnection(strCn);
2OracleCommand cmd = cn.CreateCommand();
3cmd.CommandText = "select photo from test_table";
4try
5{
6 cn.Open();
7 MemoryStream stream = new MemoryStream();
8 IDataReader reader = cmd.ExecuteReader();
9 if (reader.Read())
10 {
11 byte[] pic = (byte[])reader[0];
12 //byte[] pic = (byte[])cmd.ExecuteScalar();
13 stream.Write(pic, 0, pic.Length);
14 //Bitmap bitMap = new Bitmap(stream);
15 //Response.ContentType = "image/Jpeg";
16 //bitMap.Save(Response.OutputStream, ImageFormat.Jpeg);
17 //註解部分可以將圖片顯示在IE中,而不是下載圖片,
18 //下面的方法直接下載文件
19 Response.ContentType = "application/octet-stream";
20 Response.AddHeader("Content-Disposition", "attachment;FileName= demo.JPG");
21 Response.BinaryWrite(pic);
22 Response.End();
23 }
24
25}
26catch (Exception ex)
27{
28 Response.Write(ex.Message);
29}
30finally
31{
32 cn.Close();
33}
34
http://www.cnblogs.com/weiweictgu/archive/2006/11/17/563761.html