>  기사  >  Java  >  XML 파일을 데이터베이스로 읽는 방법

XML 파일을 데이터베이스로 읽는 방법

巴扎黑
巴扎黑원래의
2017-06-26 11:30:112417검색

xml파일을 데이터베이스로 읽습니다

첫 번째 단계는 패키지를 가져오는 것입니다

c3p0, dom4j, 자 젠, MySQL 커넥터

두 번째 단계 0Tools 5단계

xml 파일 읽기 SAXReader

xpath 방식으로

먼저 mapset에 별칭을 추가하고 읽은 파일을 탐색해야 합니다. give liste1580111763df721c6bab76afcde5ef7여섯 번째 단계인

liste1580111763df721c6bab76afcde5ef7

주었습니다 c3p0 데이터베이스에 연결하는 클래스

첫 번째 단계는 패키지를 가져오는 것입니다

c3p0,

dom4j,

jaxen,

MySQL-connector

두 번째 단계 xml 파일, config 파일 xml 파일,

config

파일

이 구체적으로 구현됩니다. 필요에 따라 Xsd

<?xml version="1.0" encoding="UTF-8"?>
<schema 
xmlns="http://www.w3.org/2001/XMLSchema" 
targetNamespace="xiaoge" 
elementFormDefault="qualified">
<element name="group">
<complexType>
<sequence maxOccurs="8" minOccurs="1">
<element name="person">
<complexType>
<sequence>
<element name="name" type="string"></element>
<element name="sex" type="string"></element>
<element name="age" type="string"></element>
</sequence>
</complexType>
</element>
</sequence>
<attribute name="id" type="int" use="required"></attribute>
</complexType>
</element>
</schema>
제약 조건 3단계

javabean

필요에 따라 구체적으로 수행4단계

c3p0

공구강습

package com.itheima.util;

import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
 
import com.mchange.v2.c3p0.ComboPooledDataSource;
 
public class C3P0Util {
private static final ComboPooledDataSource DATASOURCE = new ComboPooledDataSource();
 
public static Connection getConn(){
try {
return DATASOURCE.getConnection();
} catch (SQLException e) {
e.printStackTrace();
}
return null;
}
 
public static void release(ResultSet rs, Statement stmt, Connection conn){
if (rs != null) {
        try {
            rs.close();
        } catch (SQLException e) {
         e.printStackTrace();
        }
        rs = null;
    }
if (stmt != null) {
        try {
         stmt.close();
        } catch (SQLException e) {
         e.printStackTrace();
        }
        stmt = null;
    }
if (conn != null) {
        try {
         conn.close();
        } catch (SQLException e) {
         e.printStackTrace();
        }
        conn = null;
    }
}
}
5단계

Readxmlfile

SAXReader package com.itwjx.xml;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
 
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
import org.junit.Test;
 
import com.itwjx.entity.XMLDomain;
import com.itwjx.util.C3P0Util;
/**
 * 数据库名称 demo
 *  表名userDomain
 *  字段:  id int
 *   name varchar
 *   birthday date
 *   hobby char
 * @author WBH
 *
 */
public class WrokXmlAns {
@Test
public void readXMLtoDB(){
try {
//读取XML文件数据
List<XMLDomain> domains = readXML("src/aaa.xml");
//将数据保存到数据库
saveXMLDateToDB(domains);
} catch (Exception e) {
e.printStackTrace();
}
}
 
 
private List<XMLDomain> readXML(String path) throws DocumentException, ParseException {
SAXReader read = new SAXReader();
Document document = read.read(path);
Map<String, String> map = new HashMap<String, String>();
map.put("wbh", "xiaofan");
read.getDocumentFactory().setXPathNamespaceURIs(map);
 
List<Element> nodes = document.selectNodes("//wbh:member");
 
List<XMLDomain> domains = new ArrayList<XMLDomain>();
for (Element element : nodes) {
String id = element.attributeValue("no");
String name = element.element("name").getText();
String birthday = element.element("birthday").getText();
String hobby = element.element("hobby").getText();
 
SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd");
Date date = df.parse(birthday);
 
XMLDomain domian = new XMLDomain(
Integer.parseInt(id), name,date, hobby);
domains.add(domian);
}
return domains;
}
 
 
private void saveXMLDateToDB(List<XMLDomain> domains) {
//
Connection conn = null;
PreparedStatement ps = null;
try {
conn = C3P0Util.getConn();
ps = conn.prepareStatement("insert into userDomain values(?,?,?,?)");
for (XMLDomain user : domains) {
 
ps.setInt(1, user.getId());
ps.setString(2, user.getName());
ps.setDate(3, new java.sql.Date(user.getBirthday().getTime()));
ps.setString(4, user.getHobby());
 
ps.addBatch();
}
 
ps.executeBatch();
} catch (Exception e) {
e.printStackTrace();
} finally {
C3P0Util.release(null, ps, conn);
}
}
}

메소드

여섯 번째 단계, liste1580111763df721c6bab76afcde5ef7는 데이터베이스

private void saveXMLDateToDB(List<XMLDomain> domains) {
//
Connection conn = null;
PreparedStatement ps = null;
try {
conn = C3P0Util.getConn();
ps = conn.prepareStatement("insert into userDomain values(?,?,?,?)");
for (XMLDomain user : domains) {
 
ps.setInt(1, user.getId());
ps.setString(2, user.getName());
ps.setDate(3, new java.sql.Date(user.getBirthday().getTime()));
ps.setString(4, user.getHobby());
 
ps.addBatch();
}
 
ps.executeBatch();
} catch (Exception e) {
e.printStackTrace();
} finally {
C3P0Util.release(null, ps, conn);
}
}
에 연결하기 위한 c3p0 클래스를 제공합니다.

위 내용은 XML 파일을 데이터베이스로 읽는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.