如何使用ADO获得sqlserver数据库中image字段的值
2个回答
展开全部
Sql Server保存Image字段的值是以2进制数据保存的, 直接拿出来也可以, 如果要拿出来之后以图片显示的话, 需要Image控件, 操作步骤为:
1.创建内存流 用来保存数据 MS:=TMemoryStream.Create; M_JPEG:=TJPEGIMAGE.Create;
2.先取出数据 TBlobField(FieldByName(Image_Field)).SavetoStream(MS);
3.M_JPEG.LoadFormStream(MS); 加载流之前需要将流的指针移动到最前否则读取内存报错 Position:=0
4.Image.Picture.BitMap.Assign(M_JPEG);
这样就能显示出来了。
需要注意的是一般来说要知道图片的格式, 在加载到控件上的时候, 有时需要知道图片的格式用不同的方法加载。
1.创建内存流 用来保存数据 MS:=TMemoryStream.Create; M_JPEG:=TJPEGIMAGE.Create;
2.先取出数据 TBlobField(FieldByName(Image_Field)).SavetoStream(MS);
3.M_JPEG.LoadFormStream(MS); 加载流之前需要将流的指针移动到最前否则读取内存报错 Position:=0
4.Image.Picture.BitMap.Assign(M_JPEG);
这样就能显示出来了。
需要注意的是一般来说要知道图片的格式, 在加载到控件上的时候, 有时需要知道图片的格式用不同的方法加载。
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询