如何从数据库中读取图片,图片存在文件夹中

 我来答
猪八戒网
2023-05-18 · 百度认证:重庆猪八戒网络有限公司官方账号
猪八戒网
猪八戒网(zbj.com)创建于2006年,现已形成猪八戒网、天蓬网和线下八戒工场的“双平台+一社区”服务模式,是中国领先的人才共享平台。
向TA提问
展开全部

用读取图片数据,放到流中,Image对象从流加载数据到PictureBox。有三种方式读取图片,这三种方式都要求将的默认行为设置为。

1使用GetSqlBytes检索varbinary(max)数据:

using ( connection = new ())

{

Stream s = new ();//创建一个以内存为后备存储的流

SqlCommand command = connection.();

reader = null;

try

{

command.CommandText = "SELECT LastName,Photo FROM dbo.Employees "

" WHERE LastName=@LastName";

command.CommandType = CommandType.Text;

//声明参数并赋值

parameter = new ("@LastName", SqlDbType.NVarChar, 20);

parameter.Value = lastName;

command.Parameters.Add(parameter);

connection.Open();

//修改DataReader的默认行为,按顺序接收数据并立即加载

//指明关闭DataReader时,对数据库的连接也关闭

reader = command.(

|CommandBehavior.CloseConnection);

if (reader.HasRows)

{

while (reader.Read())

{

//SequentialAess要求按顺序接收数据,先接受reader[0]

this.label1.Text = reader[0].ToString();

if (reader.IsDBNull(1)) //若列值为空返回

return;

else

{

//使用reader.GetSqlBytes获取图像数据

SqlBytes bytes = reader.GetSqlBytes(1);

using (Bitmap proctImage = new Bitmap(bytes.Stream))

{

//以gif格式保存在Stream流并显示

proctImage.Save(s, System.Drawing.Imaging.ImageFormat.Gif);

this.pictureBox1.Image = System.Drawing.Image.FromStream(s);

} } }

}

else

MessageBox.Show("No records returned.");

2使用GetSqlBinary检索数据:

reader = command.ExecuteReader(CommandBehavior.CloseConnection);

while (reader.Read())

SqlBinary binaryStream = reader.GetSqlBinary(0);

3使用GetValue检索数据:

while (reader.Read())

{

//如果从 varbinary(max) 列读数据

byte[] binaryData = (byte[])reader.GetValue(0);

//如果从 varchar(max)或nvarchar(max) 列读数据

String stringData = (String)reader.GetValue(1);

}

  • 官方电话
  • 官方服务
    • 官方网站
    • 八戒财税
    • 知识产权
    • 八戒服务商
    • 企业需求
    • 数字市场
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式