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


感谢您的宝贵时间···

转载于:https://www.cnblogs.com/zhoulitong/p/6412304.html

要将 XML 文件的内容写入数据库,你可以使用编程语言提供的 XML 解析库和数据库连接库来完成。以下是一个通用的步骤: 1. 使用适当的编程语言(如Python、Java、或Ruby)选择一个 XML 解析库和数据库连接库。这些库通常提供了从 XML 文件提取数据和将数据插入数据库的方法和函数。 2. 使用选定的 XML 解析库读取 XML 文件并解析其内容。你可以使用适当的方法来遍历 XML 数据结构,并提取需要的数据。 3. 使用数据库连接库连接到你的数据库,并创建一个新的数据库表,该表的列应与 XML 文件的数据结构相对应。你可以使用适当的方法来执行 SQL 语句来创建表。 4. 使用数据库连接库将数据插入到数据库。你可以使用适当的方法来执行 SQL 语句将数据插入到数据库。 以下是一个使用 Python 的示例代码,使用 `xml.etree.ElementTree` 解析 XML 并将数据写入 MySQL 数据库: ```python import xml.etree.ElementTree as ET import mysql.connector # 解析XML文件 tree = ET.parse('path/to/your/xml/file.xml') root = tree.getroot() # 连接到MySQL数据库 conn = mysql.connector.connect( host="your_host", user="your_username", password="your_password", database="your_database" ) # 创建一个新表 cursor = conn.cursor() cursor.execute("CREATE TABLE IF NOT EXISTS your_table_name (column1 datatype, column2 datatype, ...)") # 插入数据 for child in root: data = [child.find('field1').text, child.find('field2').text, ...] # 根据XML的结构提取数据 sql = "INSERT INTO your_table_name (column1, column2, ...) VALUES (%s, %s, ...)" cursor.execute(sql, data) # 提交更改并关闭连接 conn.commit() conn.close() ``` 确保将 `'path/to/your/xml/file.xml'` 替换为实际的 XML 文件路径,`your_host`、`your_username`、`your_password` 和 `your_database` 分别替换为你的 MySQL 主机、用户名、密码和数据库名称,以及根据 XML 的结构和需要的字段进行调整。 根据你选择的编程语言和库,代码实现可能会有所不同,但基本的思路是解析 XML 文件并将数据插入到数据库
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值