postgresql存图片字段类型_c#保存图片到postgreSql 中

一直以为保存图片到postgreSql中表中保存图片的字段类型为bytea,经过反复测试一直没有解决,故采用了TEXT类型来保存图片,

具体方法如下:

保存:

BL层:

public bool SavePictureToDB()

{

try

{

Stream s = File.Open(file, FileMode.Open, FileAccess.Read);

int leng = 0;

if (s.Length < Int32.MaxValue)

{

leng = (int)s.Length;

}

byte[] by = new byte[leng];

s.Read(by, 0, leng);//把图片读到字节数组中

s.Close();

string str = Convert.ToBase64String(by);//把字节数组转换成字符串

StreamWriter sw = File.CreateText("G:\\11.txt");//存入11.txt文件

#region save image into data by sql

string tableName = "TestImage";

string strSql = "insert into TestImage values('1','"+str+"');";

DataAccess dao = new DataAccess();

//dao.ExceSql(strSql);

string strSql2 = "insert into TestImage values(@id,@image);";

dao.saveData("2", str, strSql2);

#endregion

sw.Write(str);

sw.Close();

sw.Dispose();

return true;

}

catch (Exception ex)

{

throw ex;

}

}

DL层:

public bool saveData(string id, string image, string strSql)

{

try

{

NConn.Open();

NpgsqlCommand objCommand = new NpgsqlCommand(strSql, NConn);

NpgsqlParameter[] para = new NpgsqlParameter[]

{

new NpgsqlParameter("@id",DbType.String,200),

new NpgsqlParameter("@image",NpgsqlDbType.Text)

};

para[0].Value=id;

para[1].Value=image;

objCommand.Parameters.Add(para[0]);

objCommand.Parameters.Add(para[1]);

if (objCommand.ExecuteNonQuery()>0)

{

return true;

}

return false;

}

catch (Exception ex)

{

throw ex;

}

}

读取:

BL层:

public void ShowPictureOfString()

{

try

{

StreamReader sr = new StreamReader("G:\\11.txt");

string s = sr.ReadToEnd();

sr.Close();

#region read data from DB

DataAccess dao = new DataAccess();

string strStr = "select image from TestImage where id ='2'";

object data = dao.ExceSqlForString(strStr);

#endregion

byte[] buf = Convert.FromBase64String(data.ToString());//把字符串读到字节数组中

//byte[] buf = (byte[])data;

MemoryStream ms = new MemoryStream(buf);

System.Drawing.Image img = System.Drawing.Image.FromStream(ms);

pictureBox1.Image = img;

//img.Save("12.jpg", System.Drawing.Imaging.ImageFormat.Jpeg);

ms.Close();

ms.Dispose();

}

catch (Exception ex)

{

throw ex;

}

}

DL层:

public object ExceSqlForString(string strSql)

{

try

{

NConn.Open();

NpgsqlCommand objCommand = new NpgsqlCommand(strSql, NConn);

object temp =objCommand.ExecuteScalar();

return temp;

}

catch (Exception ex)

{

throw ex;

}

finally

{

NConn.Close();

}

}

此上方法即可实现将图片保存到postgreSql中!

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值