用二进制大对象类型Blob实现图片入库与出库的操作
package readclobDemo.bao;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.sql.Blob;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException; import jdbcutil.bao.JdbcUtil; /**
原理: 在数据库中对Blob(二进制大对象)字段类型进行图片的存储和读取操作,其中Blob作为一个二进制文件的容器,对大数据对象进行处理;
步奏:1。在oracle数据库中建表 CREATE TABLE "HR"."T_IMAGES"
("IMAGEID" NUMBER(*,0) NOT NULL ENABLE,
"IMAGE" BLOB,
CONSTRAINT "T_IMAGES_PK" PRIMARY KEY ("IMAGEID")
),其中有Blob字段类型,对大对象数据的储存
2.本程序中定义了两个方法,writeBlob()方法主要实现向数据库中储存图片,readerBlob()方法主要实现从数据库中读取存入的图片数据
3.在Main()函数中对两个方法的声明
*/
public class WRBlobDemo { Connection conn=null;
PreparedStatement pasts=null;
ResultSet rs=null; public static void main(String[] args) throws IOException, SQLException {
WRBlobDemo a=new WRBlobDemo();
//a.writeBlob(2);
a.readBlob(2);
} public void writeBlob(int id) throws IOException, SQLException{ String sql1="insert into t_images(imageid,image) values('"+id+"',empty_blob())";
String sql2="select * from t_images where imageid=? for update ";
try {
conn=JdbcUtil.getConnection();
conn.setAutoCommit(false);//设置为手动提交
pasts=conn.prepareStatement(sql1);
pasts.executeUpdate();
System.out.println("图片存储成功!");
pasts=conn.prepareStatement(sql2);
System.out.println("图片存储成功!");
pasts.setInt(1, id);
rs=pasts.executeQuery();
System.out.println("图片存储成功!");
if(rs.next()){ Blob blob=rs.getBlob("image");
OutputStream out=blob.setBinaryStream(1L); //获得输出流,设置起始节点位置
InputStream in=new FileInputStream("F:\\images\\Img.jpg");
byte[] buffer=new byte[1024];
int lenth;
while((lenth=in.read(buffer))>0){ out.write(buffer,0,lenth);
}
System.out.println("图片存储成功!");
in.close();
out.close(); } conn.commit();
} catch (SQLException e) {
try {
conn.rollback();
} catch (SQLException e1) {
e1.printStackTrace();
}
e.printStackTrace();
}finally{
JdbcUtil.free(rs,pasts, conn);
} } public void readBlob(int id) throws IOException{
String sql="select * from t_images where imageid=? "; try {
conn=JdbcUtil.getConnection();
pasts=conn.prepareStatement(sql);
pasts.setInt(1, id);
rs=pasts.executeQuery(); if(rs.next()){ Blob blob=rs.getBlob("image");
InputStream in=blob.getBinaryStream(); //读取返回的结果集
OutputStream out=new FileOutputStream("F:\\images\\1.jpg");//将图片读取存放在指定位置
byte[] buffer=new byte[1024];
int lenth;
while((lenth=in.read(buffer))>0){ out.write(buffer,0,lenth);
}
System.out.println("图片读取成功!");
in.close();
out.close(); } } catch (SQLException e) { e.printStackTrace();
}finally{
JdbcUtil.free(rs,pasts, conn);
} } }


用二进制大对象类型Blob实现图片入库与出库的操作的更多相关文章
- MySQL_产品昨日库存与历史入库历史出库成本_20161124
产品昨日库存与历史入库历史出库成本 SELECT d.ID,a.*,e.昨日订单额 ,b.昨天入库额,b.历史2天,b.历史3天,b.历史4天,b.历史5天,b.历史6天,b.历史7天,b.历史8天, ...
- php解析入库跟出库
转载:http://www.jb51.net/article/39092.htm 数据放入数据库和取出来显示在页面需要注意什么 入库时 $str=addslashes($str); $sql=\&qu ...
- [delphi]向ImageList中加入png类型的资源图片
向ImageList中动态加入Png图片有些失真,经过多方查询,发现需要将Bitmap的AlphaFormat指定一下. //向ImageList中加入png类型的资源图片 procedure Add ...
- 不同格式图片相互转换的开源库分享(使用CxImage,并有VC6的配置过程)
不同格式图片相互转换的开源库分享 一.背景 笔者在项目的开发中,需要调用windows下的COM接口SetIconLocation来实现桌面快捷方式.而我们项目中给定的图片格式为png格式,SetIc ...
- 使用Jasperreporter生成入库出库单打印等报表操作
项目需要打印报表:就是那种生成入库单,出库单等的操作.使用到的技术:使用iReport Designer5.1.0设计报表,使用struts2+jasperreporter生成最终填充数据的报表 首先 ...
- (源代码分析)Android-Universal-Image-Loader (图片异步载入缓存库)的使用配置
转载请注明出处:http://blog.csdn.net/u011733020 前言: 在Android开发中,对于图片的载入能够说是个老生常谈的问题了,图片载入是一个比較坑的地方.处理不好,会有各种 ...
- Jetpack Compose学习(4)——Image(图片)使用及Coil图片异步加载库使用
原文地址 Jetpack Compose学习(4)--Image(图片)使用及Coil图片异步加载库使用 | Stars-One的杂货小窝 本篇讲解下关于Image的使用及使用Coil开源库异步加载网 ...
- 安卓智能POS终端手持机PDA应用仓库出入库,移库,盘点,销售开单系统
随着移动互联网的兴起,目前仓储管理所面临的的问题可以迎刃而解,WMS仓库系统解决方案通过智能终端扫描条码技术应用解决了工作量大导致工作效率不高,以及数据实时传输等问题,该方案主要提供仓库出入库,移库, ...
- 基于jQuery的图片相册滑出放大插件
今天给大家带来一款基于jQuery的图片相册滑出放大插件.点击相册图片,展示该图片.该插件适用浏览器:IE8.360.FireFox.Chrome.Safari.Opera.傲游.搜狗.世界之窗..效 ...
随机推荐
- 在ASP.NET开发中容易忽略的2个小问题
本文地址:http://www.cnblogs.com/outtamyhead/p/3642729.html,转载需保留本地址. 最近在我的MVC项目中出现了两个非常小,但是往往惹出大麻烦的问题,借中 ...
- chrome 插件 vimium 像操作vim一样的操作浏览器
感谢潘德龙同学推荐的插件非常好用整理出来一些常用快捷键记下,顺便分享! x 关闭当前页 GW 跳出浏览器 J 展示左边页签 K展示右边页签 j向下滚动 k向上滚动 /搜索 ?打开帮助 r 刷新当前页 ...
- Device eth0 does not seem to be present, delaying initialization.转载
昨天在vm里面克隆了个虚拟机,克隆之后,启动了网卡起不来,已启动就报 Device eth0 does not seem to be present, delaying initialization. ...
- Mysql 修改密码及重置密码方法
修改密码: //选择数据库 use mysql; //修改密码 update user set password=password('新密码') where user='root'; //立即生效 f ...
- 最近读cocoaui源代码有感
上半年为了做一个ios的应用,引入了cocoaui库,主要是用来布局ios界面,发现简化了不少代码和工作量.因为在写第一个ios应用的时候,用的代码布局,在适配4s和6的机型时候,几乎被搞死,大量的约 ...
- awk引用外部变量及调用系统命令方法
目标:想用awk与scp命令批量传送文件 前提:先搭好主机间的免密登陆环境(参考:http://www.cnblogs.com/tankaixiong/p/4172942.html) 实现脚本方法: ...
- IIS app pools, worker processes, app domains
Copy from http://stackoverflow.com/questions/14105345/iis-app-pools-worker-processes-app-domains I ...
- .Net 自定义应用程序配置
.Net 自定义应用程序配置 引言 几乎所有的应用程序都离不开配置,有时候我们会将配置信息存在数据库中(例如大家可能常会见到名为Config这样的表):更多时候,我们会将配置写在Web.config或 ...
- learning sql (second edition) script
create database bank; use bank; /* begin table creation */ create table department (dept_id smallint ...
- Run python as a daemon process
I am using `&`: why isn't the process running in the background? No problem. We won't show y ...