图片保存到数据库 C#

13 篇文章 0 订阅
一、图片保存到数据库


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长度不够,导致不完整,报参数无效


本篇文章来源于 Linux公社网站(www.linuxidc.com)  原文链接:http://www.linuxidc.com/Linux/2011-05/36422.htm
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值