javascript - 如何将 XML 文件保存为 Java 中 SQL Server 输出的 .xml?
问题描述
我想在 Java 中运行 SQL 查询,查询结果在 xml 中。查询结果如下——
<Root xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<Rows>
<Unique_id>6124</Unique_id>
<DoorNo>12</DoorNo>
<StreetNo>1</StreetNo>
<SiteNo>84904</SiteNo>
</Rows>
<Rows>
<Unique_id>6125</Unique_id>
<DoorNo>12</DoorNo>
<StreetNo>2</StreetNo>
<SiteNo>84904</SiteNo>
</Rows>
</Root>
现在我想使用 java 将上面的 xml 导出到一个名为 QueryResult.xml 的外部文件中。我尝试使用以下 java 脚本,但无法保存文件。
Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
con=DriverManager.getConnection("jdbc:sqlserver://sqldatabase:1009;
databaseName=DatabaseName;user=UserName;password=1234");
PreparedStatement ps=con.prepareStatement(QueryName);
ResultSet rs=ps.executeQuery();
SQLXML xmlVal1= rs.getSQLXML(1);
String val = xmlVal1.getString();
try (PrintWriter out = new PrintWriter(new File("Output.xml"))) {
out.println(val);
}
查询名称:
select Distinct Unique_id, DoorNo, StreetNo, Siteno from Table Name where
Unqiue_id IN ( '6124','6125') FOR XML RAW ('Rows'), ROOT ('Root'), ELEMENTS XSINIL;
解决方案
SQLXML xmlVal= rs.getSQLXML(1);
String val = xmlVal.getString();
try (PrintWriter out = new PrintWriter("out.xml")) {
out.println(val);
}
这是带有代码示例的 Oracle 教程。
关于您的代码,1.您忘记在结果集上制作 next() ;2.这里根本不需要SQLXML。
Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
con=DriverManager.getConnection("jdbc:sqlserver://sqldatabase:1009;
databaseName=DatabaseName;user=UserName;password=1234");
PreparedStatement ps=con.prepareStatement(QueryName);
ResultSet rs=ps.executeQuery();
rs.next();
String val = rs.getString(1);
try (PrintWriter out = new PrintWriter(new File("Output.xml"))) {
out.println(val);
}
推荐阅读
- r - 使用 R 比较一个地区的多个 5 年 ACS 估计值
- android - 需要一些帮助:任务':app:processDebugResources'的执行失败
- python - 数据帧到 csv - csv 文件未保存到本地桌面
- c++ - 如何修复在抛出“std::logic_error”实例后调用的终止 what(): basic_string::_M_construct null not valid
- python-3.x - Ansible(控制节点)可以报告它使用的 Python 版本吗?
- web - 从 GoogleMaps 检索完整的 URL
- excel - 如何在excel vba的不同单元格中循环公式?
- python - 如何替换 DataFrame 中的最后一个 empy 行(pandas,python)
- r - 使用 purrr::map 获取 '[.data.frame'(.x, ...) 中的错误:选择了未定义的列'
- kubernetes - 有没有办法仅在使用 Kubernetes 中的 HorizontalPodAutoscaler 处理消息(pod 完成其任务)时缩小 pod?