.Net中保存和读取数据库中Image类型(二进制)字段

保存入数据库           采用参数的方式传进去    

 SqlCommand myCommand =

new SqlCommand(sql, new SqlConnection(Configuration.ConnectionString));

                sql = @"update *** set imgicc=@imgicc where Imgfno = '" + formNo + "' and Imgwno = '" + workNo + "'";

 

                FileInfo iccinfo = new FileInfo(hidden_imgicc.Value);

                myCommand.Parameters.Add("@imgicc", SqlDbType.Image, (int)iccinfo.Length);

                byte[] contenticc = new byte[iccinfo.Length];

                FileStream stream = iccinfo.OpenRead();

                stream.Read(contenticc, 0, contenticc.Length);

                stream.Close();

                myCommand.Parameters["@imgicc"].Value = contenticc;

                myCommand.CommandText = sql;

                myCommand.Connection.Open();

                myCommand.ExecuteNonQuery();

                myCommand.Connection.Close();

 

读取到页面   使用WriteLocalImage方法

  if (dsImg.Tables[0].Rows[0]["imgiccPath"] != null)

                    {

                        WriteLocalImage(dsImg.Tables[0].Rows[0]["imgiccPath"].ToString());

                    }

                    else

                    {

                        WriteNoImg();

                    }

 

private void WriteBinaryImage(byte[] img)

    {

        Response.Clear();

        Response.ContentType = "image/jpeg";

        try

        {

            Response.BinaryWrite(img);

        }

        catch

        {

            WriteNoImg();

        }

    }

 

    private void WriteLocalImage(string path)

    {

        if (path.Trim() != string.Empty)

        {

            Response.Clear();

            Response.ContentType = "image/jpeg";

            Response.TransmitFile(path);

        }

        else

        {

            WriteNoImg();

        }

    }

 

    private void WriteNoImg()

    {

        Response.Write("Image is not exists.");

    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值