为了账号安全,请及时绑定邮箱和手机立即绑定

使用 java jdbc 从 Oracle 中的 Clob 字段获取错误字符

使用 java jdbc 从 Oracle 中的 Clob 字段获取错误字符

慕斯709654 2023-05-10 15:02:56
我正在尝试使用 jdbc java 从 Oracle 表中获取一个 clob 字段并将其写入文件,但有些字符写错了。public static void main(String[] args) {    Connection conn = null;    PreparedStatement ps = null;    ResultSet rs = null;    InputStreamReader st = null;     Writer wr = null;    try {          conn = DataSource.getConnection("URL", "USER", "PASS");                      ps = conn.prepareStatement("select fieldClob from tableTest");                           rs = ps.executeQuery();          while(rs.next()) {             oracle.sql.CLOB clob = (CLOB)rs.getObject("fieldClob");             st = new InputStreamReader(clob.getAsciiStream(),Charset.forName("UTF-8"));                               int intValueOfChar;             StringBuilder buffer = new StringBuilder();             while ((intValueOfChar = st.read()) != -1) {                                         buffer.append((char) intValueOfChar);                                }              wr = new FileWriter("C:/test/file.xml");              wr.write(buffer.toString());                          }    } catch (Exception e) {        // TODO Auto-generated catch block        e.printStackTrace();    } finally {        CloseObject.closeObject(rs);        CloseObject.closeObject(ps);        CloseObject.closeObject(conn);    }}}我想得到“ü”但我得到“[xBF]”或者我得到“?” 尝试 UTF-8 字符集。
查看完整描述

1 回答

?
一只名叫tom的猫

TA贡献1906条经验 获得超3个赞

更改了 Writer 并添加了对 UTF8 的支持:

Writer fstream = new OutputStreamWriter(new FileOutputStream(mergedFile), StandardCharsets.UTF_8);
查看完整回答
反对 回复 2023-05-10
  • 1 回答
  • 0 关注
  • 129 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信