数据库BLOB和CLOB插入 oracle java

============oracle 表 sql

sql 复制代码
  CREATE TABLE "SMALL19RAIN"."R_TABLE_LOB" 
   (	"R_ID" NUMBER NOT NULL ENABLE, 
	"R_CLOB" CLOB, 
	"R_BLOB" BLOB
   ) SEGMENT CREATION IMMEDIATE 
  PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 
 NOCOMPRESS LOGGING
  STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645
  PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1
  BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT)
  TABLESPACE "SMALLRAIN19TABLESPACE" 
 LOB ("R_CLOB") STORE AS SECUREFILE (
  TABLESPACE "SMALLRAIN19TABLESPACE" ENABLE STORAGE IN ROW CHUNK 8192
  NOCACHE LOGGING  NOCOMPRESS  KEEP_DUPLICATES 
  STORAGE(INITIAL 106496 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645
  PCTINCREASE 0
  BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT)) 
 LOB ("R_BLOB") STORE AS SECUREFILE (
  TABLESPACE "SMALLRAIN19TABLESPACE" ENABLE STORAGE IN ROW CHUNK 8192
  NOCACHE LOGGING  NOCOMPRESS  KEEP_DUPLICATES 
  STORAGE(INITIAL 106496 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645
  PCTINCREASE 0
  BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT)) ;

==============java 文件

java 复制代码
package org.rain.db;

import java.io.FileInputStream;
import java.io.FileReader;
import java.io.Reader;
import java.io.StringReader;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;

/**
 * 数据库BlOB和CLOB插入 
 */
public class SmallRainDBLOB {
	public static void main(String[] args) {
		Connection smallrainConn = null;
//		Statement smallrainStmt = null;
		PreparedStatement smallrainStmt = null;
		try {
			Class.forName("oracle.jdbc.driver.OracleDriver");
			smallrainConn = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:orcl", "smallrain123456789",
					"Xiaoyu123456789");
			SmallRainDBLOB smallrainDB = new SmallRainDBLOB();

//			插入clob数据String
			smallrainStmt = smallrainConn.prepareStatement("INSERT INTO R_TABLE_LOB (R_CLOB,R_ID) VALUES (?,?)");
			String smallRainclobText = "oracle数据库大数据ClOB";
			StringReader smallrainReaderString = new StringReader(smallRainclobText);
			smallrainStmt.setClob(1, smallrainReaderString);
			smallrainStmt.setInt(2, 333);
			smallrainStmt.executeUpdate();

//			插入clob文件数据,将文本文件放到当前java文件目录下,文件名为 22228.txt
			smallrainStmt = smallrainConn.prepareStatement("INSERT INTO R_TABLE_LOB (R_CLOB,R_ID) VALUES (?,?)");
			Reader smallrainFileReader = new FileReader(smallrainDB.getClass().getResource("22228.txt").getFile());

			smallrainStmt.setCharacterStream(1, smallrainFileReader);
			smallrainStmt.setInt(2, 222);
			smallrainStmt.executeUpdate();

//			插入blob数据
			smallrainStmt = smallrainConn.prepareStatement("INSERT INTO R_TABLE_LOB (R_ID, R_BLOB) VALUES (?,?)");
//			将图片文件放到当前java文件目录下,文件名为 345445.png
			FileInputStream fis = new FileInputStream(smallrainDB.getClass().getResource("345445.png").getFile());
			smallrainStmt.setInt(1, 6666);
			smallrainStmt.setBinaryStream(2, fis);
			smallrainStmt.executeUpdate();

		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			try {
				if (smallrainStmt != null) {
					smallrainStmt.close();
				}
			} catch (Exception e) {
				e.printStackTrace();
			}
			try {
				if (smallrainConn != null) {
					smallrainConn.close();
				}
			} catch (Exception e) {
				e.printStackTrace();
			}
		}
	}
}
相关推荐
zuoerjinshu2 小时前
sql实战解析-sum()over(partition by xx order by xx)
数据库·sql
毕设源码-邱学长2 小时前
【开题答辩全过程】以 基于Java的学校住宿管理系统的设计与实现为例,包含答辩的问题和答案
java·开发语言
NocoBase3 小时前
【2.0 教程】第 1 章:认识 NocoBase ,5 分钟跑起来
数据库·人工智能·开源·github·无代码
兑生4 小时前
【灵神题单·贪心】1481. 不同整数的最少数目 | 频率排序贪心 | Java
java·开发语言
daidaidaiyu4 小时前
一文学习 Spring 声明式事务源码全流程总结
java·spring
Hoshino.415 小时前
基于Linux中的数据库操作——下载与安装(1)
linux·运维·数据库
零雲5 小时前
java面试:了解抽象类与接口么?讲一讲它们的区别
java·开发语言·面试
Oueii6 小时前
Django全栈开发入门:构建一个博客系统
jvm·数据库·python
未来龙皇小蓝6 小时前
【MySQL-索引调优】11:Group by相关概念
数据库·mysql·性能优化
2401_831824967 小时前
使用Fabric自动化你的部署流程
jvm·数据库·python