【问题标题】:After extract the data from xml, data has to store in SQL Database从xml中提取数据后,数据必须存储在SQL数据库中
【发布时间】: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


【解决方案1】:

创建一个方法,说 insert(root,noOfPeople,Address,phNo,salary) 并将您要插入的所有数据以参数值一一传递到数据库中,以便逐行插入

数据库中的第 1 行将是 -

   Address : 2344 States Drive, MA 01213, USA
   Phone Number : 333-222-2222
   Salary : $3000
   Pension : $3000

数据中的第 2 行将是 -

Address : 2345 Gates Drive, PA 11213, USA
Phone Number : 444-222-2222
Salary : $3500
Pension : $3500

如果您不知道如何存储数据,请在 java 中读取 JDBC。 你也可以试试 1.How to store data in Java? Database? 2.http://www.tutorialspoint.com/jdbc/jdbc-db-connections.htm 3.http://www.tutorialspoint.com/jdbc/jdbc-insert-records.htm

【讨论】:

  • 我也想过这样做。创建一个方法并传递值并将其存储在表中。 因为我是这个话题的新手。那你能给我那个方法吗?
  • 你知道如何插入数据库,即关于 JDBC 连接吗?
  • 对不起,我不知道。
  • 我可以为您提供该方法,但这只会为您复制而不是学习。编程是关于学习而不是复制,至少您是初学者,如果您真的想然后先学习。我提到了一个链接通过它,它将帮助您获取并了解如何与数据库建立连接并使用查询,因为与数据库进行交互很重要,这对将来也有帮助。学习它。
  • 一切顺利。继续编程(y)
猜你喜欢
  • 2021-11-21
  • 1970-01-01
  • 2023-03-06
  • 2012-09-05
  • 1970-01-01
  • 1970-01-01
  • 2012-11-16
  • 2020-12-16
  • 2018-05-14
相关资源
最近更新 更多