javaclob,javaclob转string

本文目录一览:

java 怎么保存Clob对象

数据库查询出来

CLOB clob = (oracle.sql.CLOB)rs.getClob(i);

String sBlob = ClobToString(clob);

row.put(strFieldName, sBlob);

//—————

/**

*

* 功能:(将clob类型的数据转换为string)

*

* @Title: ClobToString

* @Date: 0521, 2012 17:10:52 PM

* @param clob

* @return string

*/

public String ClobToString(CLOB clob) throws SQLException, IOException {

String reString = “”;

Reader is = clob.getCharacterStream();// 得到流

BufferedReader br = new BufferedReader(is);

String s = br.readLine();

StringBuffer sb = new StringBuffer();

while (s != null) {// 执行循环将字符串全部取出付值给StringBuffer由StringBuffer转成STRING

sb.append(s);

s = br.readLine();

}

reString = sb.toString();

return reString;

}

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 存储clob字段

不可以使用update Test 语法来更新。

PreparedStatement pstat=conn.prepareStatement(sql, ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE);

ResultSet rs1 = pstat.executeQuery();

rs1.moveToInsertRow();

rs1.updateBlob(1, in, file.length() );

rs1.updateInt(2, 1);

rs1.insertRow();

in.close();

rs1.close();

pstat.close();

新增的方法,其实,修改也相似。

java clob

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

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(); } } }

java用什么读取和接收 clob字段 用的是 db2 急用,在线等

Class.forName(“COM.ibm.db2.jdbc.app.DB2Driver”).newInstance();

String url = “jdbc:db2:sample”;

Connection connection = DriverManager.getConnection(url, user, password);

connection.setAutoCommit(false);

PreparedStatement preparedStatement=connection.prepareStatement(sql);

ResultSet rs=preparedStatement.executeQuery();

Clob clob=rs.getClob(colName);

if(clob!=null)

{

Reader reader=((Oracle.sql.CLOB)clob).getCharacterStream();

BufferedReader br=new BufferedReader(reader);

String value=””;

String line=””;

while((line=br.readLine())!=null)

{

value+=line+” “;

}

}

rs.close();

preparedStatement.close();

value就是Java读取clob的值。

原创文章,作者:SNJU,如若转载,请注明出处:https://www.506064.com/n/144158.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
SNJUSNJU
上一篇 2024-10-24 15:27
下一篇 2024-10-24 15:27

相关推荐

  • c# enum转换成string

    本文将从以下几个方面详细阐述c#中enum类型转换成string类型的方法及注意事项。 一、基本语法和示例 c#中的enum类型可以看作是一组有名字的常量值,通常用于定义一组相关的…

    编程 2025-04-29
  • JWT String Argument Cannot Be Null or Empty

    JWT(JSON Web Token)是一种用于进行身份验证的标准。在使用JWT时,经常会遇到“JWT String Argument Cannot Be Null or Empt…

    编程 2025-04-27
  • Python中String包含的进阶应用

    对于Python程序员而言,String类型的操作是日常工作中必不可少的一部分。String包含的操作很多,其中最基础的操作就是判断一个字符串是否包含另一个字符串。本篇文章将对Py…

    编程 2025-04-27
  • byte字符串转string解析

    本文将会从以下几个方面对byte字符串转string做详细的阐述: 概述 转换方式 实际应用 代码实现 一、概述 字符串是编程中最常用的一种数据类型。但是,在编程中,我们经常会碰到…

    编程 2025-04-25
  • 深入探讨string类型的默认值

    一、string类型的默认值简介 在C++和许多其他编程语言中,string是一种表示字符串的数据类型。它们可以存储一个或多个字符,可以进行比较、连接和操作。string类型在声明…

    编程 2025-04-25
  • 如何将char转换为string

    一、char和string的区别 在开始讲述如何将char转换为string前,我们需要了解char和string的区别。char是C++语言的一种基础数据类型,用于表示单个字符,…

    编程 2025-04-24
  • C语言string.h中函数的详细介绍

    一、strcpy函数 strcpy函数是C语言中常用的字符串拷贝函数,其原型为: char *strcpy(char *dest, const char *src); 该函数的作用…

    编程 2025-04-23
  • Java String Reverse详解

    一、什么是Java String Reverse 在描述Java String Reverse之前,我们需要先了解什么是字符串翻转。在计算机科学中,字符串翻转是指将字符串中的字符顺…

    编程 2025-04-23
  • 深度了解string类型长度

    string类型是一种非常常用的数据类型,它在许多编程语言中都有广泛的应用。它可以表示任意长度的文本,例如字符串、HTML代码、JSON数据等等。在这篇文章中,我们将从多个方面深度…

    编程 2025-04-23
  • Java String.Join——集合转字符串的利器

    一、基本介绍 Java String.Join是Java8中一个非常实用的静态方法,它的作用是将一个集合或数组转换成一个字符串。 通常我们需要将一组数据以特殊的分隔符连接在一起,例…

    编程 2025-04-18

发表回复

登录后才能评论