javascript - 如何将Java中SQL Server输出的XML文件保存为.xml?

标签 javascript java sql-server

我想在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);
}

Here is the Oracle Tutorial with code examples .

关于你的代码, 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);
}

关于javascript - 如何将Java中SQL Server输出的XML文件保存为.xml?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51057347/

相关文章:

javascript - js 带箭头的垂直 slider

javascript - 获取 React Native 后渲染组件

java - 初始化后如何重置JLabel约束?

sql - 在 SQL Create 语句中添加命名外键约束

sql - 删除 SQL 查询中的重复行

javascript - 在 WebRTC 中公开 TURN 服务器凭据的安全问题

java - libgdx box2d body - 如何通过给定的力或速度、距离和时间移动 body

java - 在java ee项目中寻址输入流

sql-server - SSDT : "Identifiers must include at least one name (for example, MyTable)"

javascript - react 事件处理程序未在 Docusaurus 页面上执行