读取xml文件内容到数据库

这篇博客介绍了如何从XML文件中读取数据并将其写入到数据库。作者分享了一个简单的DEMO,展示了在DRP系统中,如何通过读取XML节点值并进行数据库操作。文章强调了在序列化和反序列化过程中处理数据传输的重要性,并表示作为新手,自己将持续学习。
摘要由CSDN通过智能技术生成

前言

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

内容

    听某个大牛说他们的公司常常会涉及到从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~~~


感谢您的宝贵时间···

评论 60
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

女汉纸一枚

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值