-
Notifications
You must be signed in to change notification settings - Fork 7
Expand file tree
/
Copy pathSQLtoXML_Java.java
More file actions
83 lines (64 loc) · 3.34 KB
/
SQLtoXML_Java.java
File metadata and controls
83 lines (64 loc) · 3.34 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
import java.sql.* ;
import java.io.File;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerException;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import javax.xml.transform.OutputKeys;
import org.w3c.dom.Attr;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
public class SQLtoXML_Java {
public static void main(String[] args) {
try {
String currentDir = new File("").getAbsolutePath();
String database = currentDir + "/CLData.db";
// Connect to database
Connection conn = DriverManager.getConnection("jdbc:sqlite:"+database);
conn.setAutoCommit(false);
// QUERY DATABASE
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery("SELECT * FROM cldata");
ResultSetMetaData rsmd = rs.getMetaData();
int rs_column_count = rsmd.getColumnCount();
// INITIALIZE XML DOCUMENT
DocumentBuilderFactory docFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder docBuilder = docFactory.newDocumentBuilder();
Document doc = docBuilder.newDocument();
Element rootElement = doc.createElement("CLData");
doc.appendChild(rootElement);
// BUILD NODES
while (rs.next()) {
Element mcNode = doc.createElement("missedConnection");
rootElement.appendChild(mcNode);
for(int i=1; i <= rs_column_count; i++) {
Element currNode = doc.createElement(rsmd.getColumnName(i));
currNode.appendChild(doc.createTextNode(rs.getString(i)));
mcNode.appendChild(currNode);
}
}
rs.close();
stmt.close();
conn.close();
// OUTPUT XML
TransformerFactory transformerFactory = TransformerFactory.newInstance();
Transformer transformer = transformerFactory.newTransformer();
transformer.setOutputProperty(OutputKeys.INDENT, "yes");
transformer.setOutputProperty("{http://xml.apache.org/xslt}indent-amount", "2");
DOMSource source = new DOMSource(doc);
StreamResult result = new StreamResult(new File(currentDir + "/CLData_Java.xml"));
transformer.transform(source, result);
System.out.println("Successfully migrated SQL data to XML!");
} catch (ParserConfigurationException pce) {
System.out.println(pce.getMessage());
} catch (TransformerException tfe) {
System.out.println(tfe.getMessage());
} catch (SQLException err) {
System.out.println(err.getMessage());
}
}
}