Oracle,导出XML的问题( oracle.xml.sql.OracleXMLSQLException: Cannot map Unicode to Oracle character.)(急!)

shellfj 2006-11-14 05:03:12
用Oracle,XSU做一个导出XML的程序.
从AREA这张表,取出数据,导出为XML,Orcle的版本是9.2.0..字符集是"US7ASCII".
Area这张表有一列是存储的中文(存进数据库之前,有经过转换).会抛出异常:
Exception in thread "main" oracle.xml.sql.OracleXMLSQLException: Cannot map Unicode to Oracle character.
at oracle.xml.sql.core.OracleXMLConvert.getXML(OracleXMLConvert.java:1015)
at oracle.xml.sql.query.OracleXMLQuery.getXMLString(OracleXMLQuery.java:267)
at oracle.xml.sql.query.OracleXMLQuery.getXMLString(OracleXMLQuery.java:221)
at oracle.xml.sql.query.OracleXMLQuery.getXMLString(OracleXMLQuery.java:198)
at procedure.OracleXmlParse.main(OracleXmlParse.java:32)

程序的lib: jdbc14.jar,xmlparserv2.jar,xdb.jar,nls_charset12.jar,xsu12.jar.
代码:
public class OracleXmlParse {
public static void main(String[] args) {
try{
DriverManagerDataSource dataSource = new DriverManagerDataSource ("oracle.jdbc.driver.OracleDriver",
"jdbc:oracle:thin:@168.1.1.136:1521:imis","ims","ims");
String selectSQL = "select AREA_CODE,AREA_NAME,REGION_CODE,AREA_NAME_CN from AREA";
OracleXMLQuery query = new OracleXMLQuery(conn,selectSQL);
query.setEncoding("UTF-8");
String str = query.getXMLString();
System.out.println(str);
conn.close();
}catch(SQLException e){
e.printStackTrace();
}
}
}

如果,selectSQL = "select AREA_CODE,AREA_NAME,REGION_CODE,from AREA".程序就没有问题.因为,这些列存储的都是英文字符.只有AREA_NAME_CN 这一列存的是中文.

希望大家帮忙.小弟先谢谢了.
...全文
385 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
zuguanqun 2007-04-17
  • 打赏
  • 举报
回复
up
dhxyu 2007-04-16
  • 打赏
  • 举报
回复
用Oracle,XSU做一个导出XML的程序

这个怎么做?给个思路或者提示 谢谢!1·
shellfj 2006-11-19
  • 打赏
  • 举报
回复
这个问题,我已经解决了.谢谢你们的回答.
Goal3 2006-11-16
  • 打赏
  • 举报
回复
去掉这行呢
//query.setEncoding("UTF-8");
shellfj 2006-11-15
  • 打赏
  • 举报
回复
感谢你们的回答.

To:tonyzhangcn(东尼)
To:hbwhwang(catmiw的ID已经停用,现在用这个)

你们两个的想法,都差不多,我有试过,都是可以的,但是那样会很慢.
主要是想用XSU(XML SQL Utility)做导出XML,因为,这样速度会比较快.
hbwhwang 2006-11-14
  • 打赏
  • 举报
回复
能不能用Statement.executeQuery把数据搞到ResultSet里面?
如果可以的话,就自己写段代码,把ResultSet里面的数据转到XML中。
tonyzhangcn 2006-11-14
  • 打赏
  • 举报
回复
AREA_NAME_CN值先拿出来,用的时候再转码不行吗?
shellfj 2006-11-14
  • 打赏
  • 举报
回复
up...自己顶....

67,512

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧