1. <var id="fe6gj"></var>

    <rp id="fe6gj"><nav id="fe6gj"></nav></rp>

    <noframes id="fe6gj"><cite id="fe6gj"></cite>

    <ins id="fe6gj"><button id="fe6gj"><p id="fe6gj"></p></button></ins>
    1. <tt id="fe6gj"><i id="fe6gj"><sub id="fe6gj"></sub></i></tt>
        始創于2000年 股票代碼:831685
        咨詢熱線:0371-60135900 注冊有禮 登錄
        • 掛牌上市企業
        • 60秒人工響應
        • 99.99%連通率
        • 7*24h人工
        • 故障100倍補償
        您的位置: 網站首頁 > 幫助中心>文章內容

        C#對Oracle數據庫中圖片的處理

        發布時間:  2012/8/22 17:10:30

        由于Oracle課程設計中涉及到圖片的處理,測試了好長的時間和查閱了很多的資料,終于把這個問題解決了,在這和大家分享一下:

        一、圖片保存到數據庫

        Oracle中一般保存圖片的類型為blob,一般的步驟為:

        1,首先把圖片轉化為二進制(byte[])

            FileStream fs = new FileStream(filepath, FileMode.Open, FileAccess.Read);
        -
         

                        byte[] buffByte = new byte[fs.Length];
                        fs.Read(buffByte, 0, Convert.ToInt32(fs.Length));
                        fs.Close();

        2,把二進制保存到Oracle數據庫

             string strconn = "data source = oem;user id= exam; password=exam;persist security info=false;";
                        OracleConnection conn = new OracleConnection(strconn);
                        conn.Open();
                        OracleCommand comm = new OracleCommand("addUser", conn);//存儲過程adduser
                        comm.CommandType = CommandType.StoredProcedure;
                        comm.Parameters.Add("i_name", OracleType.VarChar, 50);
                        comm.Parameters.Add("i_pic", OracleType.Blob);
                        //comm.Parameters.Add("i_result", OracleType.Int32);
                        comm.Parameters[0].Value = this.textBox2.Text;
                        comm.Parameters[1].Value = buffByte;//這個為圖片的二進制形式
                        //comm.Parameters[2].Direction = ParameterDirection.Output;
                        comm.ExecuteNonQuery();

            conn.Close();

        二、讀取Oracle數據庫轉化為圖片www.linuxidc.com

        步驟:

        1、讀出二進制

         string strconn = "data source = oem;user id= exam; password=exam;persist security info=false;";
                    OracleConnection conn = new OracleConnection(strconn);
                    conn.Open();
                    OracleCommand comm = new OracleCommand("selectUser", conn);
                    comm.CommandType = CommandType.StoredProcedure;
                    comm.Parameters.Add("flag", OracleType.Int32);
                    comm.Parameters.Add("i_name", OracleType.VarChar, 50);
                    comm.Parameters.Add("cur_out", OracleType.Cursor);
                    comm.Parameters[0].Value = 2;
                    comm.Parameters[1].Value = this.comboBox1.SelectedValue.ToString();
                    comm.Parameters[2].Direction = ParameterDirection.Output;
                    OracleDataAdapter da = new OracleDataAdapter(comm);
                    DataSet ds = new DataSet();
                    da.Fill(ds);

            conn.close();

        2、轉化為圖片

        if (ds.Tables[0].Rows.Count > 0)
                    {
                        MemoryStream buf = new MemoryStream();
                        byte[] blob = (byte[])ds.Tables[0].Rows[0]["pic"];//
                        buf.Write(blob, 0, blob.Length);
                        Image image = Image.FromStream(buf);
                        pictureBox2.Image = image;
                    }

        涉及到的存儲過程

         //create or replace procedure addUser
                        //(i_name in U_INFO.NAME%type,
                        // i_pic  in u_info.pic%type

                        // )
                        // is
                        // begin
                        //   insert into U_INFO(name,pic) values(i_name,i_pic);
                        // end adduser;

         

        //create or replace procedure selectUser
                    //(flag in int,
                    // i_name  in u_info.name%type,
                    // cur_out  out  sys_refcursor
                    // )
                    // is
                    // begin
                    //  if flag=1 then
                    //     open cur_out for
                    //      select name from U_Info;
                    //  end if;
                    //  if flag=2 then
                    //     open cur_out for
                    //      select * from U_Info where name=i_name;
                    //  end if;
                    // end selectUser;

        注:在此遇見的問題

         Image.FromStream(buf);這塊報參數無效

        可能的原因:

        1,圖片轉化為二進制是出現問題,導致讀取的二進制不能轉化為圖片,所以報參數無效

        2,讀取時轉化出錯,可能byte長度不夠,導致不完整,報參數無效


        本文出自:億恩科技【www.endtimedelusion.com】

        服務器租用/服務器托管中國五強!虛擬主機域名注冊頂級提供商!15年品質保障!--億恩科技[ENKJ.COM]

      1. 您可能在找
      2. 億恩北京公司:
      3. 經營性ICP/ISP證:京B2-20150015
      4. 億恩鄭州公司:
      5. 經營性ICP/ISP/IDC證:豫B1.B2-20060070
      6. 億恩南昌公司:
      7. 經營性ICP/ISP證:贛B2-20080012
      8. 服務器/云主機 24小時售后服務電話:0371-60135900
      9. 虛擬主機/智能建站 24小時售后服務電話:0371-60135900
      10. 專注服務器托管17年
        掃掃關注-微信公眾號
        0371-60135900
        Copyright© 1999-2019 ENKJ All Rights Reserved 億恩科技 版權所有  地址:鄭州市高新區翠竹街1號總部企業基地億恩大廈  法律顧問:河南亞太人律師事務所郝建鋒、杜慧月律師   京公網安備41019702002023號
          0
         
         
         
         

        0371-60135900
        7*24小時客服服務熱線

         
         
        av不卡不卡在线观看_最近2018年中文字幕_亚洲欧美一区二区三区_一级A爱做片免费观看国产_日韩在线中文天天更新_伊人中文无码在线