zoukankan      html  css  js  c++  java
  • 读取xml文件内容到数据库

    前言

        前言不搭后语··················

    内容

        听某个大牛说他们的公司常常会涉及到从xml文件中读数据到写入到数据库,序列化的时候会遇到这这个问题,将要持久化的数据到xml文件存储起来,为了方便数据的传输。看了xml的读取还是很有意思的。在DRP中,我勇哥讲到从xml文件中读节点值写入到数据库中。下面是这个小demo,小的学业不精,见到块块代码需得及时收集。

    • xml文件

    <?xml version="1.0" encoding="utf-8"?>
    <ACCESOS>
    	<item>
    		<SOCIO>
    			<NUMERO>00045050</NUMERO>
    			<REPOSICION>0</REPOSICION>
    			<NOMBRE>MOISES MORENO</NOMBRE>
    			<TURNOS>
    				<LU>T1</LU>
    				<MA>T2</MA>
    				<MI>T3</MI>
    				<JU>T4</JU>
    				<VI>T5</VI>
    				<SA>T6</SA>
    				<DO>T7</DO>
    			</TURNOS>
    		</SOCIO>
    	</item>
    	<item>
    		<SOCIO>
    			<NUMERO>00045051</NUMERO>
    			<REPOSICION>0</REPOSICION>
    			<NOMBRE>RUTH PENA</NOMBRE>
    			<TURNOS>
    			<LU>S1</LU>
    			<MA>S2</MA>
    			<MI>S3</MI>
    			<JU>S4</JU>
    			<VI>S5</VI>
    			<SA>S6</SA>
    			<DO>S7</DO>
    			</TURNOS>
    		</SOCIO>
    	</item>
    </ACCESOS>

    • 用到的jar包


    • 后台读取数据并写入数据库代码

    String sql = "insert into T_XML(NUMERO, REPOSICION, NOMBRE, TURNOS) values (?, ?, ?, ?)";
    Connection conn = null;
    PreparedStatement pstmt = null;
    try {
    	conn = DbUtil.getConnection();
    	pstmt = conn.prepareStatement(sql);
    	Document doc = new SAXReader().read(new File("C:/Users/zhou/Workspaces/MyEclipse 10/test_xmlImport/xml/test01.XML"));
    	List itemList = doc.selectNodes("/ACCESOS/item/SOCIO");
    	for (Iterator iter=itemList.iterator(); iter.hasNext();) {
    		Element el = (Element)iter.next();
    		String numero = el.elementText("NUMERO");
    		String reposicion = el.elementText("REPOSICION");
    		String nombre = el.elementText("NOMBRE");
    		List turnosList = el.elements("TURNOS");
    		StringBuffer sbString = new StringBuffer();
    		for (Iterator iter1=turnosList.iterator(); iter1.hasNext();) {
    			Element turnosElt = (Element)iter1.next();
    			String lu = turnosElt.elementText("LU");
    			String ma = turnosElt.elementText("MA");
    			String mi = turnosElt.elementText("MI");
    			String ju = turnosElt.elementText("JU");
    			String vi = turnosElt.elementText("VI");
    			String sa = turnosElt.elementText("SA");
    			String doo = turnosElt.elementText("DO");
    			sbString.append(lu + "," + ma + "," + mi + "," + ju + "," + vi + "," + sa + "," + doo);
    		}
    		pstmt.setString(1, numero);
    		pstmt.setString(2, reposicion);
    		pstmt.setString(3, nombre);
    		pstmt.setString(4, sbString.toString());
    		pstmt.addBatch();
    	}
    	pstmt.executeBatch();
    	System.out.println("将XML导入数据库成功!");
    } catch (Exception e) {
    	e.printStackTrace();
    } finally {
    	DbUtil.close(pstmt);
    	DbUtil.close(conn);
    }

    小结

        菜鸟还需努力,go~~~


    感谢您的宝贵时间···

  • 相关阅读:
    解决chrome浏览器无法得到window.showModalDialog返回值的问题
    Javascript 中 null、NaN和undefined的区别
    Windows Server 2003 asp网页不能访问的常见问题
    关于SQLServer无法对数据库'XXX'执行删除,因为它正用于复制。错误:'3724' 的解决方案
    关于Gridview激发了未处理的事件“RowDeleting”错误的处理
    ASP.NET中实现文件下载功能
    C#中ref和out的作用和区别
    关于Pascal(帕斯卡)以及Camel(驼峰)命名法
    期末作业验收
    SDN第五次上机作业
  • 原文地址:https://www.cnblogs.com/zhoulitong/p/6412304.html
Copyright © 2011-2022 走看看