数据库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();
			}
		}
	}
}
相关推荐
小研说技术8 小时前
Spring AI实现rag流程(简易版)
java·后端
亓才孓8 小时前
【本地项目引用外部库的类,想修改字段遇到的请缓存的问题】
java·maven
小林敲代码77888 小时前
记录一下IDEA中很多变量变色的方案
java·开发语言·spring boot·idea
lixora8 小时前
Oracle 11g Active Data Guard Go 自动化部署工具 v1.0
数据库·oracle
Nturmoils8 小时前
自增主键别只会 auto_increment,先把值从哪来讲清楚
数据库·后端
南知意-8 小时前
IDEA 2026.1最新版安装教程
java·ide·intellij-idea·idea安装·idea激活
叶小鸡8 小时前
Java 篇-项目实战-AI 天机学堂(从 0 到 1)-day5
数据库·redis·缓存
星子落怀aa8 小时前
Java 反复报错?Gemini助力修复
java
半夜修仙9 小时前
RabbitMQ中如何保证消息的可靠性传输
java·分布式·中间件·rabbitmq·github·java-rabbitmq
Flittly9 小时前
【AgentScope Java新手村系列】(3)工具系统
java·spring boot·spring