国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

用ASP.NET 2.0在Oracle中存取圖片(文件)的操作

2019-11-18 16:52:42
字體:
來源:轉載
供稿:網友

有時由于某種需要(如安全性)須將圖片或文件存放在數據庫中,當然一般情況下特別是文件比較大的時候很多人不提倡將文件以二進制的形式存放在數據庫中的,現將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://m.survivalescaperooms.com/weiweictgu/archive/2006/11/17/563761.html


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 河西区| 卓资县| 汉寿县| 辽阳市| 遂宁市| 阆中市| 塘沽区| 分宜县| 饶河县| 博乐市| 西平县| 蒙山县| 肃宁县| 辽宁省| 勐海县| 砚山县| 克什克腾旗| 象山县| 南京市| 舟曲县| 自治县| 辉县市| 平乐县| 沙田区| 松江区| 黄梅县| 开阳县| 南靖县| 贵定县| 台湾省| 丹巴县| 安宁市| 潮安县| 平武县| 商南县| 丁青县| 蒙城县| 泸水县| 祁门县| 遂川县| 庐江县|