读取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~~~


感谢您的宝贵时间···

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


php输出xml格式字符串
J2ME Mobile 3D入门教程系列文章之一
XML轻松学习手册
XML入门的常见问题(一)
XML入门的常见问题(三)
XML轻松学习手册(2)XML概念
xml文件介绍及使用
xml编程(一)-xml语法
XML文件结构和基本语法
第2章 包装类
XML入门的常见问题(二)
Java对象的强、软、弱和虚引用
JS解析XML文件和XML字符串详解
java中枚举的详细使用介绍
了解Xml格式
XML入门的常见问题(四)
深入SQLite多线程的使用总结详解
PlayFramework完整实现一个APP(一)
XML和YAML的使用方法
XML轻松学习总节篇