用二进制大对象类型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.傲游.搜狗.世界之窗..效 ...
随机推荐
- WCF学习日记
图书馆借阅了<WCF高级编程>,从6.11开始学习wcf,希望尽快熟悉原理和编程模型以及常用编程方法. WCF是一个平台,也是一个框架,从Net.3.0 就在Net framewo ...
- MySQL server has gone away 问题的解决方法
mysql出现ERROR : (2006, 'MySQL server has gone away') 的问题意思就是指client和MySQL server之间的链接断开了. 造成这样的原因一般是s ...
- IDL中histogram的应用
前面一段时间在使用Histogram时一直是不能更好的理解其中的奥秘,通过阅读帮助以及查看相应的文档,终于理解了其中的玄机,很多时候是因为在学习的时候英文不知道翻译成什么样的内容比较合理,这样就给后面 ...
- 常用CSS Reset汇总
什么是Css Reset呢? 在 HTML标签在浏览器里有默认的样式,不同浏览器的默认样式之间也会有差别.在切换页面的时候,浏览器的默认样式往往会给我们带来麻烦,影响开发效率.所以解决的方法就是一开始 ...
- 关于MySQL的Admin Ping Command
前言: 最近在线上诊断QPS飙升的过程中深入进行了下Admin Ping Command的测试.此外,再一些国外文章中最近也读到了一些相关知识,所以写成一篇博文做一下总结. 1. 关于Admin Pi ...
- UML系列01之 UML和绘图工具Visio介绍
概要 UML,全称是Unified Modeling Language,中文是"统一建模语言".通俗点说,UML是一种创建模型的语言.UML是在开发阶段,说明,可视化,构建和书写一 ...
- 数据可视化(5)--jqplot经典实例
本来想把实例也写到上篇博客里,最后发现太长了,拆成两篇博客了. 实例来源于官方文档:http://www.jqplot.com/tests/ 这篇博客主要是翻译了官方文档关于经典实例的解说,并在相应代 ...
- 【转载】dirs、pushd、popd指令
转载自:http://hi.baidu.com/linuxtrip/item/47a38c8eec00e98f4414cfb7 一.目录栈指令 目录栈是用户最近访问过的系统目录列表,并以堆栈的形式管理 ...
- php中mysql操作的buffer知识
php与mysql的连接有三种方式,mysql,mysqli,pdo.不管使用哪种方式进行连接,都有使用buffer和不使用buffer的区别. 什么叫使用buffer和不使用buffer呢? 客户端 ...
- Mysql大量插入随机数据方法--存储过程
创建测试表: mysql)); 创建存储过程: mysql> delimiter // mysql> create procedure rand_data(in num int) -> ...