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实现图片入库与出库的操作的更多相关文章

  1. MySQL_产品昨日库存与历史入库历史出库成本_20161124

    产品昨日库存与历史入库历史出库成本 SELECT d.ID,a.*,e.昨日订单额 ,b.昨天入库额,b.历史2天,b.历史3天,b.历史4天,b.历史5天,b.历史6天,b.历史7天,b.历史8天, ...

  2. php解析入库跟出库

    转载:http://www.jb51.net/article/39092.htm 数据放入数据库和取出来显示在页面需要注意什么 入库时 $str=addslashes($str); $sql=\&qu ...

  3. [delphi]向ImageList中加入png类型的资源图片

    向ImageList中动态加入Png图片有些失真,经过多方查询,发现需要将Bitmap的AlphaFormat指定一下. //向ImageList中加入png类型的资源图片 procedure Add ...

  4. 不同格式图片相互转换的开源库分享(使用CxImage,并有VC6的配置过程)

    不同格式图片相互转换的开源库分享 一.背景 笔者在项目的开发中,需要调用windows下的COM接口SetIconLocation来实现桌面快捷方式.而我们项目中给定的图片格式为png格式,SetIc ...

  5. 使用Jasperreporter生成入库出库单打印等报表操作

    项目需要打印报表:就是那种生成入库单,出库单等的操作.使用到的技术:使用iReport Designer5.1.0设计报表,使用struts2+jasperreporter生成最终填充数据的报表 首先 ...

  6. (源代码分析)Android-Universal-Image-Loader (图片异步载入缓存库)的使用配置

    转载请注明出处:http://blog.csdn.net/u011733020 前言: 在Android开发中,对于图片的载入能够说是个老生常谈的问题了,图片载入是一个比較坑的地方.处理不好,会有各种 ...

  7. Jetpack Compose学习(4)——Image(图片)使用及Coil图片异步加载库使用

    原文地址 Jetpack Compose学习(4)--Image(图片)使用及Coil图片异步加载库使用 | Stars-One的杂货小窝 本篇讲解下关于Image的使用及使用Coil开源库异步加载网 ...

  8. 安卓智能POS终端手持机PDA应用仓库出入库,移库,盘点,销售开单系统

    随着移动互联网的兴起,目前仓储管理所面临的的问题可以迎刃而解,WMS仓库系统解决方案通过智能终端扫描条码技术应用解决了工作量大导致工作效率不高,以及数据实时传输等问题,该方案主要提供仓库出入库,移库, ...

  9. 基于jQuery的图片相册滑出放大插件

    今天给大家带来一款基于jQuery的图片相册滑出放大插件.点击相册图片,展示该图片.该插件适用浏览器:IE8.360.FireFox.Chrome.Safari.Opera.傲游.搜狗.世界之窗..效 ...

随机推荐

  1. Android应用安全之外部动态加载DEX文件风险

    1. 外部动态加载DEX文件风险描述 Android 系统提供了一种类加载器DexClassLoader,其可以在运行时动态加载并解释执行包含在JAR或APK文件内的DEX文件.外部动态加载DEX文件 ...

  2. Java知多少(111)数据库之修改记录

    修改数据表记录也有3种方案. 一.使用Statement对象 实现修改数据表记录的SQL语句的语法是:    update表名 set 字段名1 = 字段值1,字段名2 = 字段值2,……where特 ...

  3. java中getBytes方法可能使图片文件产生的问题

    InputStream is = new FileInputStream(fl); ImageInputStream iis = ImageIO.createImageInputStream(is); ...

  4. Screensiz.es – 最流行移动设备及显示器的屏幕规格大全

    Screensiz.es 帮助您快速找到目前市场上最流行的设备和显示器的屏幕规格.尺寸数据来自维基百科,使用更好理解的像素密度.流行度推算自 Google 查询(从 AdWords 流量估算),以及一 ...

  5. 一个ListView布局的不断演化

    刚出来工作,就负责一个APP的某块功能的编写,该功能就是类似微博那样的界面.微博界面的编写实际上是非常复杂的,虽然它只是一个ListView,但要想让这个ListView滑得动,是的,在一些配置低的手 ...

  6. SQL Server里的INTERSECT ALL

    在上一篇文章里,我讨论了INTERSECT设置操作的基础,它和INNER JOIN的区别,还有为什么需要好的索引设计支持.今天我想谈下SQL Server里并未实现的INTERSECT ALL操作. ...

  7. css中filter:alpha透明度使用

    css中filter:alpha透明度使用    使用filter可以设置透明度,filter:alpha在IE下是没有问题的,要支持firefox就需要使用-moz-opacity,下面有个不错的示 ...

  8. QCustomplot使用分享(六) 坐标轴和网格线

    一.概述 前边已经写了5篇对QCustomPlot的讲解,看过上述的几篇文章后,基本就能做一些简单的使用了,但是如果想要做到高度的控制图表,那么坐标轴将是很重要的一部分,因为坐标轴就是图表的一个参考系 ...

  9. node生成自定义命令(yargs/commander)

    第一部分可以生成一个自定义命令,例如常见的”express”,yargs和commander则可以在生成的自定义命令上做扩展,yargs将命令扩展成类似express --l xx的形式;而comma ...

  10. 当我们安装使用时,会出现eclipse启动不了,出现“Java was started but returned exit code=13......”的问题

    安装win8.1后,启动eclipse,也会提示 "java was started but returned exit code=13" 可能是eclipse.ini配置文件错误 ...