【发布时间】:2014-03-16 13:53:21
【问题描述】:
我编写了从 xml 中提取数据并提供以下输出的 Java 程序。 提取完成后,数据必须存储在 SQL 数据库中。请帮我在SQL数据库中添加数据,
以下输出必须存储在数据库中,
输出:-
Root element of the doc is geodata
Total no of people : 2
Address : 2344 States Drive, MA 01213, USA
Phone Number : 333-222-2222
Salary : $3000
Pension : $3000
Address : 2345 Gates Drive, PA 11213, USA
Phone Number : 444-222-2222
Salary : $3500
Pension : $3500
源代码:-
package com.techassignment;
import java.io.File;
import org.w3c.dom.Document;
import org.w3c.dom.*;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.DocumentBuilder;
import org.xml.sax.SAXException;
import org.xml.sax.SAXParseException;
public class readxml
{
public static void main (String argv [])
{
try {
DocumentBuilderFactory docBuilderFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder docBuilder = docBuilderFactory.newDocumentBuilder();
Document doc = docBuilder.parse(new File("C:\\Users\\mkar\\workspace\\techassignment - new\\src\\com\\techassignment\\testFinal.xml"));
// normalize text representation
doc.getDocumentElement ().normalize ();
System.out.println ("Root element of the doc is " +
doc.getDocumentElement().getNodeName());
NodeList listOfPersons = doc.getElementsByTagName("person");
int totalPersons = listOfPersons.getLength();
System.out.println("Total no of people : " + totalPersons);
for(int s=0; s<listOfPersons.getLength() ; s++){
Node firstPersonNode = listOfPersons.item(s);
if(firstPersonNode.getNodeType() == Node.ELEMENT_NODE){
Element firstPersonElement = (Element)firstPersonNode;
//-------
NodeList addressList = firstPersonElement.getElementsByTagName("address");
Element addressElement = (Element)addressList.item(0);
NodeList textFNList = addressElement.getChildNodes();
System.out.println("Address : " +
((Node)textFNList.item(0)).getNodeValue().trim());
//-------
NodeList phonenumberList = firstPersonElement.getElementsByTagName("phonenumber");
Element phonenumberElement = (Element)phonenumberList.item(0);
NodeList textLNList = phonenumberElement.getChildNodes();
System.out.println("Phone Number : " +
((Node)textLNList.item(0)).getNodeValue().trim());
//----
NodeList salaryList = firstPersonElement.getElementsByTagName("salary");
Element salaryElement = (Element)salaryList.item(0);
NodeList textAgeList = salaryElement.getChildNodes();
System.out.println("Salary : " +
((Node)textAgeList.item(0)).getNodeValue().trim());
//----
NodeList PensionList = firstPersonElement.getElementsByTagName("pension");
Element PensionElement = (Element)salaryList.item(0);
NodeList textPensionList = salaryElement.getChildNodes();
System.out.println("Pension : " +
((Node)textPensionList.item(0)).getNodeValue().trim());
//------
}//end of if clause
}//end of for loop with s var
}catch (SAXParseException err) {
System.out.println ("** Parsing error" + ", line "
+ err.getLineNumber () + ", uri " + err.getSystemId ());
System.out.println(" " + err.getMessage ());
}catch (SAXException e) {
Exception x = e.getException ();
((x == null) ? e : x).printStackTrace ();
}catch (Throwable t) {
t.printStackTrace ();
}
//System.exit (0);
}//end of main
}
【问题讨论】:
-
只是数据...连接到您的数据库,启动 INSERT 查询,完成。
标签: java sql sql-server xml nodelist