XML为数据库进行增删改查(实例)
//增删改查文件
package xml2;
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.io.PrintWriter;
import java.io.UnsupportedEncodingException;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
import org.xml.sax.XMLReader;
public class Dom4jReadExmple {
public File file =new File(System.getProperty("user.dir")+File.separator+"dd"+File.separator+"hy.xml");
//遍历所有
public void getSelectedNodeValue(List<Student> list){
if(!file.exists()){
System.out.println("文件不存在");
}
SAXReader saxReader = new SAXReader();
try {
Document document= saxReader.read(file);
Element rootElement= document.getRootElement();
Iterator iterator=document.selectNodes("//student").iterator();
while(iterator.hasNext()){
Student student = new Student();
College college = new College();
Element elem =(Element) iterator.next();
student.setAge(Integer.parseInt(elem.attributeValue("age")==null?"0":elem.attributeValue("age")));
student.setName(elem.element("name").getText());
college.setName(elem.element("college").getText());
college.setLeader(elem.element("college").attributeValue("leader"));
student.setCollege(college);
student.setTelephone(elem.elementText("telephone"));
student.setNote(elem.elementText("notes"));
System.out.println(student.getName());
System.out.println(student.getAge());
System.out.println(student.getTelephone());
System.out.println(student.getCollege().getName());
System.out.println(student.getCollege().getLeader());
System.out.println(student.getNote());
System.out.println("============================");
list.add(student);
}
} catch (DocumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
//插入数据
public void insertIntoXML(Student stu){
try {
if(!file.exists()){
file.createNewFile();
PrintWriter writer =new PrintWriter(new FileOutputStream(file));
writer.write("<?xml version='1.0' encoding='UTF-8'?>");
writer.write("\n");
writer.write("<all>");
writer.write("\n");
writer.write("</all>");
writer.flush();
writer.close();
// 或
// BufferedWriter bufferedWriter = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(file)));
// bufferedWriter.write("<?xml version='1.0' encoding='UTF-8'?>");
// bufferedWriter.write("\n");
// bufferedWriter.write("<all>");
// bufferedWriter.write("\n");
// bufferedWriter.write("</all>");
// bufferedWriter.flush();
// bufferedWriter.close();
}
Document document= DocumentHelper.createDocument();
Element root=document.addElement("students");
root.addComment("所有部门信息");
Element element =root.addElement("student");
element.addAttribute("id", stu.getId().toString());
element.addElement("age").addText(stu.getAge().toString());
element.addElement("name").addText(stu.getName());
Element element2 =element.addElement("college");
element2.addText(stu.getCollege().getName());
element2.addAttribute("leader", stu.getCollege().getLeader());
element.addElement("telephone").addText(stu.getTelephone());
element.addElement("notes").addText(stu.getNote());
SAXReader saxReader = new SAXReader();
Document document2=saxReader.read(file);
if(null!=document2){
List lists=document2.selectNodes("//student");
if(null!=lists&&lists.size()>0){
Iterator iterator =lists.iterator();
while(iterator.hasNext()){
Element element4 =(Element) iterator.next();
Element element5 =root.addElement("student");
element5.addAttribute("id", element4.attributeValue("id"));
element5.addElement("age").addText(element4.elementText("age"));
element5.addElement("name").addText(element4.elementText("name"));
element5.addElement("college").addText(element4.elementText("college")).addAttribute("leader", element4.element("college").attributeValue("leader"));
element5.addElement("telephone").addText(element4.elementText("telephone"));
element5.addElement("notes").addText(element4.elementText("notes"));
}
}
}
XMLWriter xmlWriter = new XMLWriter(new FileOutputStream(file));
xmlWriter.write(document);
xmlWriter.close();
} catch (DocumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
// 通过id删除
public void deleteFormXml(int id){
SAXReader saxReader = new SAXReader();
try {
Document document=saxReader.read(file);
Iterator iterator=document.selectNodes("//student[@id]").iterator();
while(iterator.hasNext()){
Element element =(Element) iterator.next();
if(element.attributeValue("id").equals(String.valueOf(id))){
document.getRootElement().remove(element);
}
}
XMLWriter xmlWriter = new XMLWriter(new FileOutputStream(file));
xmlWriter.write(document);
xmlWriter.flush();
xmlWriter.close();
} catch (DocumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
// 修改对应id数据
public void editXML(Student stu){
SAXReader saxReader =new SAXReader();
try {
Document document =saxReader.read(file);
Iterator iterator=document.selectNodes("//student[@id]").iterator();
while(iterator.hasNext()){
Element element =(Element) iterator.next();
if(element.attributeValue("id").equals(String.valueOf(stu.getId()))){
element.element("name").setText(stu.getName());
element.element("age").setText(stu.getAge().toString());
element.element("college").setText(stu.getCollege().getName());
element.element("college").setAttributeValue("leader", stu.getCollege().getLeader());
element.element("telephone").setText(stu.getTelephone());
element.element("notes").setText(stu.getNote());
}
}
XMLWriter xmlWriter = new XMLWriter(new FileOutputStream(file));
xmlWriter.write(document);
xmlWriter.flush();
xmlWriter.close();
} catch (DocumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
XML为数据库进行增删改查(实例)的更多相关文章
- java:JSP(JSPWeb.xml的配置,动态和静态导入JSP文件,重定项和请求转发,使用JSP实现数据库的增删改查实例)
1.JSP的配置: <%@ page language="java" import="java.util.*" pageEncoding="UT ...
- python链接oracle数据库以及数据库的增删改查实例
初次使用python链接oracle,所以想记录下我遇到的问题,便于向我这样初次尝试的朋友能够快速的配置好环境进入开发环节. 1.首先,python链接oracle数据库需要配置好环境. 我的相关环境 ...
- Android学习---数据库的增删改查(sqlite CRUD)
上一篇文章介绍了sqlite数据库的创建,以及数据的访问,本文将主要介绍数据库的增删改查. 下面直接看代码: MyDBHelper.java(创建数据库,添加一列phone) package com. ...
- java jdbc 连接mysql数据库 实现增删改查
好久没有写博文了,写个简单的东西热热身,分享给大家. jdbc相信大家都不陌生,只要是个搞java的,最初接触j2ee的时候都是要学习这么个东西的,谁叫程序得和数据库打交道呢!而jdbc就是和数据库打 ...
- Mybatis学习笔记(二) 之实现数据库的增删改查
开发环境搭建 mybatis 的开发环境搭建,选择: eclipse j2ee 版本,mysql 5.1 ,jdk 1.7,mybatis3.2.0.jar包.这些软件工具均可以到各自的官方网站上下载 ...
- Android中Sqlite数据库进行增删改查
今天这篇文章写Sqlite数据库,通过一个小案例来完整讲一下数据库常见的CRUD操作. 先对知识点总结: SQLite数据库 轻量级关系型数据库 创建数据库需要使用的api:SQLiteOpenHel ...
- Java操作数据库实现"增删改查"
本文主要讲解JDBC操作数据库 主要实现对MySql数据库的"增删改查" 综合概述: JDBC的常用类和接口 一 DriverManager类 DriverManage类 ...
- [译]聊聊C#中的泛型的使用(新手勿入) Seaching TreeVIew WPF 可编辑树Ztree的使用(包括对后台数据库的增删改查) 字段和属性的区别 C# 遍历Dictionary并修改其中的Value 学习笔记——异步 程序员常说的「哈希表」是个什么鬼?
[译]聊聊C#中的泛型的使用(新手勿入) 写在前面 今天忙里偷闲在浏览外文的时候看到一篇讲C#中泛型的使用的文章,因此加上本人的理解以及四级没过的英语水平斗胆给大伙进行了翻译,当然在翻译的过程中发 ...
- 用SpringBoot+MySql+JPA实现对数据库的增删改查和分页
使用SpringBoot+Mysql+JPA实现对数据库的增删改查和分页 JPA是Java Persistence API的简称,中文名Java持久层API,是JDK 5.0注解或XML描述 ...
随机推荐
- Scala学习笔记--List、ListBuffer
ListBuffer(列表缓冲) ListBuffer类位于 scala.collection.mutable.ListBuffer val buf = new ListBuffer[Int] va ...
- soapUI参数中文乱码问题解决方法 (groovy脚本中文乱码)
soapUI参数中文乱码问题解决方法 可能方案1: 字体不支持中文,将字体修改即可: file-preferences-editor settings-select font 修改字体,改成能显示中文 ...
- 递归实现全排列序列C语言实现
大家好,我是小鸭酱,博客地址为:http://www.cnblogs.com/xiaoyajiang 以下鄙人用递归回溯的办法,采用C语言实现了全排列序列,用以某些优化方案的原始方案的给定 #incl ...
- javascript if 和else 语句练习
1.标准体重://男士体重=身高-100±3<br />//女士体重=身高-110±3<br />//输入性别.身高.体重,查看体重是否标准. <script type= ...
- [HDU] 1698 Just a Hook [线段树区间替换]
Just a Hook Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
- 转载:常见EXE文件反编译工具
PE Explorer V1.99 R5 绿色汉化特别版_强大的可视化汉化集成工具 功能极为强大的可视化汉化集成工具,可直接浏览.修改软件资源,包括菜单.对话框.字符串表等: 另外,还具备有 W32D ...
- 可以让javascript加快的脚本(收藏了)
<?php ob_start('ob_gzhandler'); header("Cache-Control: public"); h ...
- Linux iostat监测IO状态(转)
Linux iostat监测IO状态 2010-03-1 | 13:13分类:Linux,技术细节 | 标签:Linux | 53,945 views Linux系统出现了性能问题,一般我 ...
- mysql5.5 无法创建实例,error 16001
今天想用jdbc做个小程序,结果发现好久不用的mysql不好用了,我装的是社区版(win7)环境下,按理说不可能出问题,找了一堆解决方案都没解决,准备重装的时候想把mysql服务停了,直接在dos输入 ...
- Tomcat部署项目通过—IP地址:端口访问
如题所示,实现效果图如下: 设置如下: (1)修改${tomcat}/config/sever.xml文件虚拟内容目录: <Engine name="Catalina" de ...