JAVA操作ORACLE大对象
一:操作CLOB
(1)数据库表结构如下:
create table CLOB_TEST
(
ID VARCHAR2(5) not null,
CONTENT CLOB
)
(2)插入CLOB
方法一:第一步插入一个空值,第二步锁住此行,更新clob字段
public static void insertClob(Connection conn,String data) throws Exception{ //这句话如没有,9i的驱动下会报 java.sql.SQLException: ORA-01002: 读取违反顺序 的异常。 conn.setAutoCommit(false);
//插入一个空CLOB String insertSql = "insert into clob_test(id,content) values('1',empty_clob())"; //查询插入的空CLOB String selectSql = "select content from clob_test where id = '1' for update"; PreparedStatement stmt = conn.prepareStatement(insertSql); stmt.executeUpdate(); stmt.close(); // lock this line PreparedStatement pstmt = conn.prepareStatement(selectSql); ResultSet rs = pstmt.executeQuery(); if(rs.next()){ oracle.sql.CLOB clob = (oracle.sql.CLOB)rs.getClob(1); //为CLOB写信息 BufferedWriter out = new BufferedWriter(clob.getCharacterOutputStream()); BufferedReader in = new BufferedReader(new FileReader(data)); int c; while ((c=in.read())!=-1) { out.write(c); } in.close(); out.close(); } conn.commit(); pstmt.close(); }
注:此方法在jdk1.4、jdk50、jdk6.0和Oracle9i、Oracle10g、Oracle11g驱动下测试通过!
方法二:通过setString方法
public static void insertClob(Connection conn,String data) throws Exception{ String insertSql = "insert into clob_test(id,content) values('1',?)"; PreparedStatement stmt = conn.prepareStatement(insertSql); stmt.setString(1, data); stmt.executeUpdate(); stmt.close(); conn.close();
}
注:由于在Oracle9i的驱动下,setString 有2000字符长度的限制,故这个方法只适合Oracle10g以上的驱动(Oracle11g驱动+JDK6.0也测试通过)。
方法三:通过setClob方法
public static void insertClob(Connection conn,String filePath) throws Exception{ String insertSql = "insert into clob_test(id,content) values('1',?)"; PreparedStatement stmt = conn.prepareStatement(insertSql); stmt.setClob(1, new FileReader(filePath)); stmt.executeUpdate(); stmt.close(); conn.commit(); }
注:由于setClob(int parameterIndex, Reader reader)这个方法是JDBC4.0规范刚加的内容,是以流的方式为CLOB赋值的。并且Oracle9i驱动、Oracle10g驱动、JDK1.4、JDK1.5是基于JDBC3.0规范的,只有Oracle11g驱动+JDK6.0才是基于JDBC4.0规范的,所以目前这个方法只适合Oracle11g驱动(ojdbc6.jar)+JDK6.0!
(3)读取CLOB
方法一:
public static String readClob(Connection conn) throws Exception{ PreparedStatement stmt = conn.prepareStatement("select * from clob_test where id = '1'"); ResultSet rs = stmt.executeQuery(); String str=""; StringBuffer sb = new StringBuffer(""); while(rs.next()){ Clob clob = rs.getClob("content"); Reader is = clob.getCharacterStream(); BufferedReader br = new BufferedReader(is); str = br.readLine(); while (str != null) { sb.append(str); str = br.readLine(); } } return sb.toString(); }
方法二:
public static String readClob(Connection conn) throws Exception{ PreparedStatement stmt = conn.prepareStatement("select * from clob_test where id = '1'"); ResultSet rs = stmt.executeQuery(); String str=""; while(rs.next()){ str = rs.getString("content"); } return str; }
注:由于在Oracle9i的驱动下,rs.getString 返回为null,所以此方法只适合Oracle10g及其以上驱动。
二:操作BLOB
(1)数据库表结构如下:
create table BLOB_TEST
(
ID VARCHAR2(5) not null,
CONTENT BLOB
)
(2)插入BLOB
方法一:第一步插入一个空值,第二步锁住此行,更新blob字段
public static void writeBlob(Connection con,String filePath) throws Exception{ FileInputStream fis = null; PreparedStatement psm = null; File file = new File(filePath); psm = con.prepareStatement("insert into blob_test(id,content) values('2',empty_blob())"); psm.executeUpdate(); psm = con.prepareStatement("select content from blob_test where id ='2' for update"); ResultSet rs = psm.executeQuery(); if(rs.next()){ oracle.sql.BLOB blob = (oracle.sql.BLOB)rs.getBlob(1); FileInputStream fin = new FileInputStream(file); OutputStream out = blob.getBinaryOutputStream(); int count = -1, total = 0; byte[] data = new byte[blob.getBufferSize()]; while ((count = fin.read(data)) != -1) { out.write(data, 0, count); } out.flush(); out.close();
} }
方法二:通过setBinaryStream方法
public static void writeBlob(Connection con,String filePath) throws Exception{ FileInputStream fis = null; PreparedStatement psm = null; File file = new File(filePath); try { fis = new FileInputStream(file); psm = con.prepareStatement("insert into blob_test(id,content) values('2',?)"); psm.setBinaryStream(1, fis, fis.available()); psm.executeUpdate(); }finally{ if(fis != null) fis.close(); psm.close(); con.close(); } }
方法三:通过setBlob(int parameterIndex, InputStream inputStream)方法
public static void writeBlob(Connection con,String filePath) throws Exception{ FileInputStream fis = null; PreparedStatement psm = null; File file = new File(filePath); try { fis = new FileInputStream(file); psm = con.prepareStatement("insert into blob_test(id,content) values('2',?)"); psm.setBlob(1, fis); psm.executeUpdate(); }finally{ if(fis != null) fis.close(); psm.close(); con.close(); } }
注:由于setBlob(int parameterIndex, InputStream inputStream)这个方法是JDBC4.0规范刚加的内容,是以流的方式为BLOB赋值的。并且Oracle9i驱动、Oracle10g驱动、JDK1.4、JDK1.5是基于JDBC3.0规范的,只有Oracle11g驱动+JDK6.0才是基于JDBC4.0规范的,所以目前这个方法只适合Oracle11g驱动(ojdbc6.jar)+JDK6.0!
(3)读取BLOB
public static void readBlob(Connection con,String outFilePath){ Statement sm = null; ResultSet rs = null; try { sm = con.createStatement(); rs = sm.executeQuery("select * from blob_test where id = 2"); if(rs.next()){ Blob blob = rs.getBlob("content"); File file = new File(outFilePath); FileOutputStream sout = new FileOutputStream(file); InputStream in = blob.getBinaryStream();//获取BLOB数据的输入数据流 //经BLOB输入数据流读取数据,并将其写入文件 byte[] b = new byte[256]; int off = 0; int len = b.length; for (int i = in.read(b); i != -1;) { sout.write(b); i = in.read(b); } sout.close(); rs.close(); sm.close(); con.close(); } } catch (Exception e) { e.printStackTrace(); } }
JAVA操作ORACLE大对象的更多相关文章
- Java操作Oracle
public class DBCon { // 数据库驱动对象 public static final String DRIVER = "oracle.jdbc.driver.OracleD ...
- java 操作Oracle 批量入库的问题
java 操作Oracle 批量入库的问题 先说下我运行的环境: Windows7 64位操作系统 (四核)Intel i5-2300 CPU @2.80GHz 内存4G 硬盘1T Jdk1.6+My ...
- java操作oracle的blob,clob数据
一.区别和定义 LONG: 可变长的字符串数据,最长2G,LONG具有VARCHAR2列的特性,可以存储长文本一个表中最多一个LONG列 LONG RAW: 可变长二进制数据,最长2G CLOB: ...
- JAVA操作ORACLE数据库的存储过程
一.任务提出 JAVA操作oracle11g存储过程实验需要完成以下几个实例: 1.调用没有返回参数的过程(插入记录.更新记录) 2.有返回参数的过程 3.返回列表的过程 4.返回带分页的列表的过程. ...
- ORACLE大对象存储
--创建有大对象字段的一张表 create table test001 ( fname varchar2(50), content blob ) select * from ...
- Java操作Oracle数据库以及调用存储过程
操作Oracle数据库 publicclass DBConnection { //jdbc:oracle:thin:@localhost:1521:orcl publicstaticf ...
- Java 操作Oracle数据库
import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import ...
- JAVA处理Blob大对象
Blob对象是SQL Blob的Java语言映射.SQL Blob是一个内置类型,它可以将一个二进制大对象保存在数据库中.接口ResultSet.CallableStatement和PreparedS ...
- Java操作Redis存储对象类型数据
背景描述 关于JAVA去操作Redis时,如何存储一个对象的数据,大家是非常关心的问题,虽然官方提供了存储String,List,Set等等类型,但并不满足我们现在实际应用.存储一个对象是是 ...
随机推荐
- ubuntu上安装python的ldap模块
首先安装 apt-get install libldap2-dev 然后再安装 apt-get install libsasl2-dev 然后就可以继续安装你的python-ldap模块了 pip i ...
- typeScript模块<二>
/*模块 1 模块的的概念 2 模块导出的几种方法 1.export 导出声明 2.export 导出语句 3.export default 4.import导入模块 3 模块化封装上一讲的DB库 * ...
- Linux命令 – ln 软连接与硬链接区别介绍
ln命令可以生成软链接和硬链接,也可叫做符号链接和实体链接. 有兴趣深入理解的可以查阅相关文档,一般的读者只需记住以下几点即可: 不管是软链接还是硬链接都不会额外增加磁盘空间(虽然实际情况可能会多占用 ...
- Spring cloud微服务安全实战-4-9Zuul网关安全开发(二)
把在微服务里面写的安全的相关逻辑挪到网关里面来.这样把安全逻辑和业务逻辑解耦开.那么这些问题就都解决了. 先来看下之前的安全的代码,首先在之类做了认证,认证服务器去认证,拿这个token去换用户信息. ...
- 【Redis】Redis Sentinel 哨兵模式搭建
Redis Sentinel介绍 Redis Sentinel是Redis的官方高可用性解决方案 Redis Sentinel为Redis提供高可用性.实际上,这意味着使用Sentinel可以创建一个 ...
- xshell连接中标麒麟
中标麒麟: 1.首先肯定需要给虚拟机配置静态ip,让虚拟机作为独立的ip存在 https://www.cnblogs.com/judes/p/11776872.html 2.输入rpm -qa | g ...
- 【442】Remote control GUP Linux
参考:上传文件到GPU服务器并运行文件 参考:WinSCP 参考:Python远程调试图文教程(一)之Pycharm Remote Debug 参考:教程 | 使用 PyCharm 连接服 ...
- CentOS7下yum安装Redis
(1).Redis概述 Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value(键值型)数据库(非关系型数据库),并提供多种语言的API. Redi ...
- 123457123456#0#----com.DoraGame.YingYu65--前拼后广--儿童英语doraX
com.DoraGame.YingYu65--前拼后广--儿童英语doraX
- Python爬虫-爬取豆瓣图书Top250
豆瓣网站很人性化,对于新手爬虫比较友好,没有如果调低爬取频率,不用担心会被封 IP.但也不要太频繁爬取. 涉及知识点:requests.html.xpath.csv 一.准备工作 需要安装reques ...