java代码插入clob java clob

java clob

java clob是什么,让我们一起了解一下?

创新互联基于成都重庆香港及美国等地区分布式IDC机房数据中心构建的电信大带宽,联通大带宽,移动大带宽,多线BGP大带宽租用,是为众多客户提供专业移动服务器托管报价,主机托管价格性价比高,为金融证券行业服务器托管,ai人工智能服务器托管提供bgp线路100M独享,G口带宽及机柜租用的专业成都idc公司。

CLOB是内置类型,将字符大对象存储为数据库表某一行中的一个列值。默认情况下,驱动程序使用SQL locator实现Clob对象,这意味着CLOB对象包含一个指向SQL CLOB数据的逻辑指针而不是数据本身。

在JAVA如何使用CLOB进行操作?

在绝大多数情况下,有2种方法使用CLOB。

1、相对比较小的,可以用String进行直接操作,把CLOB看成字符串类型即可。

2、如果比较大,可以用 getAsciiStream 或者 getUnicodeStream 以及对应的 setAsciiStream 和 setUnicodeStream 即可。

(1)读取数据:

ResultSet rs = stmt.executeQuery("SELECT TOP 1 * FROM Test1"); rs.next(); Reader reader = rs.getCharacterStream(2);

(2)插入数据:

PreparedStatement pstmt = con.prepareStatement("INSERT INTO test1 (c1_id, c2_vcmax) VALUES (?, ?)"); pstmt.setInt(1, 1); pstmt.setString(2, htmlStr); pstmt.executeUpdate();

(3)更新数据:

Statement stmt = con.createStatement(); ResultSet rs = stmt.executeQuery("SELECT * FROM test1"); rs.next(); Clob clob = rs.getClob(2); long pos = clob.position("dog", 1); clob.setString(1, "cat", len, 3); rs.updateClob(2, clob); rs.updateRow();

那么java是如何操作数据库clob字段的?

示例代码如下: package com.test.db.clob; import java.io.BufferedReader; import java.io.IOException; import java.io.Writer; import java.sql.Clob; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; public class ClobTest {undefined private static Connection conn; static {undefined try {undefined Class.forName("oracle.jdbc.driver.OracleDriver"); conn = DriverManager.getConnection( "jdbc:oracle:thin:@localhost:1521:orcl","scott","tiger"); } catch (ClassNotFoundException e) {undefined e.printStackTrace(); } catch (SQLException e) {undefined e.printStackTrace(); } } public static void main(String[] args) throws SQLException, IOException {undefined testInsert(); testUpdate(); testRead(); } private static void testInsert() throws SQLException {undefined String sql = "insert into test_clob values(1, empty_clob())"; Statement stm = conn.createStatement(); stm.execute(sql); } private static void testUpdate() throws SQLException, IOException {undefined String sql = "select content from test_clob where id = 1 for update"; Statement stm = conn.createStatement(); ResultSet rs = stm.executeQuery(sql); while (rs.next()) {undefined Clob c = rs.getClob(1); c.truncate(0);// clear Writer w = c.setCharacterStream(1);//The first position is 1 w.write("abc"); w.close(); c.setString(c.length() + 1, "abc"); conn.commit(); } } private static void testRead() throws SQLException, IOException {undefined String sql = "select content from test_clob where id = 1"; PreparedStatement pstm = conn.prepareStatement(sql); ResultSet rs = pstm.executeQuery(); while (rs.next()) {undefined Clob clob = rs.getClob("content"); System.out.println("clob.getSubString(1, 2) -- " + clob.getSubString(1, 2)); System.out.println("clob.getSubString(1, (int)clob.length()) -- " + clob.getSubString(1, (int)clob.length())); BufferedReader r = new BufferedReader(clob.getCharacterStream()); String s; while ((s = r.readLine()) != null) {undefined System.out.println(s); } r.close(); } } }

blob字段java如何处理

1.使用jdk中的方法进行传输。在ResultSet 中有getBlob()方法,在PreparedStatement中有setBlob()方法,所以大多数人都会尝试setBlob

(),getBlob() 进行读写,或者两个数据库之间BLOB的传输。这种方法实际上是行不通的,据网上的一些资料介绍,说sun官方的文档有些方法

都是错误的。

2.使用ResultSet.getBinaryStream 和PreparedStatement.setBinaryStream对BLOB进行读写或两个数据库间的传输。这种方法我自己尝试过,

发现,如果BLOB中存储的是文本文件的话,就没问题,如果是二进制文件,传输就会有问题。

根据自己的经验,以及查阅了Oracle的官方文档,都是使用如下处理方法:

1.新建记录,插入BLOB数据

1.1首先新建记录的时候,使用oracle的函数插入一个空的BLOB,假设字段A是BLOB类型的:

insert xxxtable(A,B,C) values(empty_blob(),'xxx','yyyy')

1.2后面再查询刚才插入的记录,然后更新BLOB,在查询前,注意设置Connection的一个属性:

conn.setAutoCommit(false);如果缺少这一步,可能导致fetch out of sequence等异常.

1.3 查询刚才插入的记录,后面要加“ for update ”,如下:

select A from xxxtable where xxx=999 for update ,如果缺少for update,可能出现row containing the LOB value is not locked

的异常

1.4 从查询到的 BLOB字段中,获取blob并进行更新,代码如下:

BLOB blob = (BLOB) rs.getBlob("A");

OutputStream os = blob.getBinaryOutputStream();

BufferedOutputStream output = new BufferedOutputStream(os);

后面再使用output.write方法将需要写入的内容写到output中就可以了。例如我们将一个文件写入这个字段中:

BufferedInputStream input = new BufferedInputStream(new File("c://hpWave.log").toURL().openStream());

byte[] buff = new byte[2048];  //用做文件写入的缓冲

int bytesRead;

while(-1 != (bytesRead = input.read(buff, 0, buff.length))) {

output.write(buff, 0, bytesRead);

System.out.println(bytesRead);

}

上面的代码就是从input里2k地读取,然后写入到output中。

1.5上面执行完毕后,记得关闭output,input,以及关闭查询到的ResultSet

1.6最后执行conn.commit();将更新的内容提交,以及执行conn.setAutoCommit(true); 改回Connction的属性

2.修改记录,方法与上面的方法类似,

2.1首先更新BLOB以外的其他字段

2.2 使用1.3中类似的方法获取记录

2.3 修改的过程中,注意以下:a 需要更新的记录中,BLOB有可能为NULL,这样在执行blob.getBinaryOutputStream()获取的值可能为

null,那么就关闭刚才select的记录,再执行一次update xxxtable set A = empty_blob() where xxx, 这样就先写入了一个空的BLOB(不是null),然后再

使用1.3,1.4中的方法执行更新记录.b 注意别忘了先执行setAutoCommit(false),以及"for update",以及后面的conn.commit();等。

3.读取BLOB字段中的数据.

3.1 读取记录不需要setAutoCommit(),以及 select ....for update.

3.2 使用普通的select 方法查询出记录

3.3 从ResultSet中获取BLOB并读取,如下:

BLOB b_to = (BLOB) rs.getBlob("A");

InputStream is = b_from.getBinaryStream();

BufferedInputStream input = new BufferedInputStream(is);

byte[] buff = new byte[2048];

while(-1 != (bytesRead = input.read(buff, 0, buff.length))) {

//在这里执行写入,如写入到文件的BufferedOutputStream里

System.out.println(bytesRead);

}

通过循环取出blob中的数据,写到buff里,再将buff的内容写入到需要的地方

4.两个数据库间blob字段的传输

类似上面1和3的方法,一边获取BufferedOutputStream,另外一边获取BufferedInputStream,然后读出写入,需要注意的是写入所用的

Connection要执行conn.setAutoCommit(false);以及获取记录时添加“ for update ”以及最后的commit();

总结以上方法,其根本就是先创建空的BLOB,再获取其BufferedOutputStream进行写入,或获取BufferedInputStream进行读取

(1)对数据库clob型执行插入操作 

************************************************* 

java.sql.PreparedStatement pstmt = null; 

ResultSet rs = null; 

String query = ""; 

conn.setAutoCommit(false); 

query = "insert into clobtest_table(id,picstr) values(?,empty_clob())"; 

java.sql.PreparedStatement pstmt = conn.prepareStatement(query); 

pstmt.setString(1,"001"); 

pstmt.executeUpdate(); 

pstmt = null 

query = "select picstr from clobtest_table where id = '001' for update"; 

pstmt = con.prepareStatement(query) 

rs= pstmt.executeQuery(); 

oracle.sql.CLOB clobtt = null; 

if(rs.next()){ 

clobtt = (oracle.sql.CLOB)rs.getClob(1); 

Writer wr = clobtt.getCharacterOutputStream(); 

wr.write(strtmp); 

wr.flush(); 

wr.close(); 

rs.close(); 

con.commit(); 

(2)通过sql/plus查询是否已经成功插入数据库 

************************************************* 

PL/SQL的包DBMS_LOB来处理LOB数据。察看刚才的插入是否成功。使用DBMS_LOB包的getlength这个procedure来检测是否已经将str存入到picstr字段中了。如: 

SQL select dbms_lob.getlength(picstr) from clobtest_table; 

(3)对数据库clob型执行读取操作 

************************************************* 

读取相对插入就很简单了。基本步骤和一半的取数据库数据没有太大的差别。 

String description = "" 

query = "select picstr from clobtest_table where id = '001'"; 

pstmt = con.prepareStatement(query); 

ResultSet result = pstmt.executeQuery(); 

if(result.next()){ 

oracle.jdbc.driver.OracleResultSet ors = 

(oracle.jdbc.driver.OracleResultSet)result; 

oracle.sql.CLOB clobtmp = (oracle.sql.CLOB) ors.getClob(1); 

if(clobtmp==null || clobtmp.length()==0){ 

System.out.println("======CLOB对象为空 "); 

description = ""; 

}else{ 

description=clobtmp.getSubString((long)1,(int)clobtmp.length()); 

System.out.println("======字符串形式 "+description); 

}

java在oracle数据库中怎么插入读取CLOB值

参考:

/**

* 写入、更新CLOB字段的代码示例

*/

public void writeClob() {

//自定义的数据库连接管理类 

Connection conn = DbManager.getInstance().getConnection();

try {

conn.setAutoCommit(false);

// 1.这种方法写入CLOB字段可以。

PreparedStatement stat = conn

.prepareStatement("insert into t_clob (id,clobfield) values(sys_guid(),?)");

String clobContent = "This is a very very long string";

StringReader reader = new StringReader(clobContent);

stat.setCharacterStream(1, reader, clobContent.length());

stat.executeUpdate();

// 2.使用类似的方法进行更新CLOB字段,则不能成功 

// stat.close();

// stat =null;

// stat =

// conn.prepareStatement("update t_clob set clobfield=? where id=1");

// stat.setCharacterStream(1, reader, clobContent.length());

// stat.executeUpdate();

// 3.需要使用for update方法来进行更新,

// 但是,特别需要注意,如果原来CLOB字段有值,需要使用empty_clob()将其清空。

// 如果原来是null,也不能更新,必须是empty_clob()返回的结果。

stat = conn

.prepareStatement("select clobfield from t_clob where id='1' for update");

ResultSet rs = stat.executeQuery();

if (rs.next()) {

oracle.sql.CLOB clob = (oracle.sql.CLOB) rs

.getClob("clobfield");

Writer outStream = clob.getCharacterOutputStream();

char[] c = clobContent.toCharArray();

outStream.write(c, 0, c.length);

outStream.flush();

outStream.close();

}

conn.commit();

} catch (SQLException | IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

DbManager.getInstance().closeConnection(conn);

}

java将string插入到类型为clob的ORACLE库中

1:首先:写个连接数据库的类,里面有返回mysq, oracle连接的方法

public Connection getConn(String flag){

Connection con=null;

try

{

if(flag.equals("1"))

{

Class.forName(“oracle.jdbc.driver.OracleDriver”);

con = DriverManager.getConnection(“jdbc:oracle:thin:@IP:1521:数据库名字”,"name","password");

}

if(flag.equals("2"))

{

Class.forName("org.gjt.mm.mysql.Driver");

con = DriverManager.getConnection("jdbc:mysql://localhost/数据库名?user=用户名password=密码useUnicode=truecharacterEncoding=GBK");

}

}

catch(Exception e)

{

e.printStackTrace();

}

return con;

}

2:执行插入操作

public void setData() {

conn = new Conn();

try {

String sqlfrom = "select p.id,p.content from table p order by p.id ";

String sqlinsert = "insert into table values(?,?)";

con = conn.getConn("2");

stmt = con.createStatement(); //从mysql取出大字段

rs = stmt.executeQuery(sqlfrom);

con = conn.getConn("1");

PreparedStatement pstmt = con.prepareStatement(sqlinsert); //向oracle中插入大字段

int i = 0;

while (rs.next()) {

pstmt.setInt(1, rs.getInt(1));

pstmt.setClob(2, oracle.sql.CLOB.empty_lob());

pstmt.executeUpdate(); //插入时将大字段设为空

this.updateOne(con,rs.getInt(1),rs.getString(2)); // 这里调用然后更新这个大字段

}

rs.close(); //关闭相关连接

pstmt.close();

stmt.close();

con.close();

} catch (Exception e) {

e.printStackTrace();

try

{

con.rollback();

} catch (Exception e1) {

System.out.println("回滚出现异常!");

e1.printStackTrace();

}

}

}

3:该方法实现对应大字段记录的更新

public void updateOne(Connection con,int id, String content) {

String str = "select t.content from table t where t.id=" + id+ " for update";

try {

// 注意:存取操作开始前,必须用setAutoCommit(false)取消自动提交,否则Oracle将抛出“读取违反顺序”的错误。

con.setAutoCommit(false);

stmt = con.createStatement();

ResultSet rs_clob = stmt.executeQuery(str);

while ( rs_clob .next()) {

/* 取出clob数据*/

oracle.sql.CLOB clob = (oracle.sql.CLOB) rs_clob .getClob(1);

/* 向clob中写入数据*/

clob.putString(1, content);

}

stmt.close();

con.commit();

con.setAutoCommit(true);

con.close();

} catch (Exception e) {

e.printStackTrace();

try

{

con.rollback();

} catch (Exception e1) {

System.out.println("回滚出现异常!");

e1.printStackTrace();

}

}

}

现在就完成了一行记录的更新。

4:读clob字段以String 的形式返回(当然也可以将读到的内容写入文件,大家改一下就可以了)

/**

* 读clob字段

* @param con

* @param id

* @return

*/

public String readClob(Connection con,int id)

{

String content="";

try

{

con.setAutoCommit(false);

stmt=con.createStatement();

ResultSet rs_clob=stmt.executeQuery("select t.content from table t where t.id="+id);

oracle.sql.CLOB contents=null;

while (rs_clob.next())

{ // 取出CLOB对象

contents= (oracle.sql.CLOB) rs_clob.getClob(1);

}

BufferedReader a = new BufferedReader(contents.getCharacterStream()); //以字符流的方式读入BufferedReader

String str = "";

while ((str = a.readLine()) != null) {

content = content.concat(str); //最后以String的形式得到

}

con.commit();

/*

BufferedWriter out = new BufferedWriter(new FileWriter("e:/test.txt"));

out.write(content); //写入文件

out.close(); */

con.setAutoCommit(true);

con.close();

}catch(Exception e)

{

System.out.println("出现异常");

e.printStackTrace();

try

{

con.rollback();

}

catch (Exception e1)

{

System.out.println("回滚出现异常!");

e1.printStackTrace();

}

}

return content;

}


标题名称:java代码插入clob java clob
文章路径:http://hbruida.cn/article/ddcijhe.html