java读取orcale中clob数据方法,不会乱码的!

  1. package com.logcd.common;
  2. import java.io.BufferedReader;
  3. import java.io.File;
  4. import java.io.FileInputStream;
  5. import java.io.InputStreamReader;
  6. import java.io.Reader;
  7. import java.io.Writer;
  8. import java.net.HttpURLConnection;
  9. import java.net.URL;
  10. import java.sql.Connection;
  11. import java.sql.DriverManager;
  12. import java.sql.ResultSet;
  13. import java.sql.SQLException;
  14. import java.sql.Statement;
  15. import org.apache.commons.io.FileUtils;
  16. import oracle.sql.CLOB;
  17. public class OracleClob {
  18. public static void main(String[] args) {
  19. Integer id = saveClobDataUseSQL("测试", getFileContentAsString(
  20. "D:/uploadDir/test.txt", true));
  21. readClobDataUseSQL(id, new File("D:/uploadDir/test2.txt"));
  22. }
  23. /**
  24. * 保存Clob数据
  25. *
  26. * @param name
  27. * 数据名称
  28. * @param data
  29. * 字串
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Oracle,要读取CLOB(字符大型对象)的内容,可以使用DBMS_LOB包提供的函数和过程来实现。 首先,我们需要使用SELECT语句查询包含CLOB字段的表,并使用TO_LOB函数将CLOB字段转换为LOB类型。例如: SELECT TO_LOB(clob_column) AS clob_content FROM my_table; 然后,我们可以使用DBMS_LOB包提供的函数和过程来读取CLOB内容。 一种常用的方法是使用DBMS_LOB.GETLENGTH函数获取CLOB的长度。例如: DECLARE clob_len NUMBER; BEGIN SELECT DBMS_LOB.GETLENGTH(clob_content) INTO clob_len FROM my_table; DBMS_OUTPUT.PUT_LINE('CLOB长度为:' || clob_len); END; 接下来,我们可以使用DBMS_LOB.SUBSTR函数获取CLOB的子串。该函数的第一个参数是CLOB对象,第二个参数是要获取的子串的起始位置,第三个参数是要获取的子串的长度。例如: DECLARE clob_content CLOB; BEGIN SELECT clob_content INTO clob_content FROM my_table; DBMS_OUTPUT.PUT_LINE('CLOB的前100个字符为:' || DBMS_LOB.SUBSTR(clob_content, 1, 100)); END; 另外,如果CLOB内容很大,我们需要逐块地读取它。可以使用DBMS_LOB.READ函数来读取CLOB的一部分内容。 DECLARE clob_content CLOB; buffer VARCHAR2(4000); amount NUMBER := 4000; offset NUMBER := 1; BEGIN SELECT clob_content INTO clob_content FROM my_table; LOOP EXIT WHEN offset > DBMS_LOB.GETLENGTH(clob_content); DBMS_LOB.READ(clob_content, amount, offset, buffer); DBMS_OUTPUT.PUT_LINE(buffer); offset := offset + amount; END LOOP; END; 以上就是在Oracle读取CLOB内容的一些基本方法。具体使用哪种方法取决于应用的需求和CLOB字段的具体特征。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值