//增删改查文件

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为数据库进行增删改查(实例)的更多相关文章

  1. java:JSP(JSPWeb.xml的配置,动态和静态导入JSP文件,重定项和请求转发,使用JSP实现数据库的增删改查实例)

    1.JSP的配置: <%@ page language="java" import="java.util.*" pageEncoding="UT ...

  2. python链接oracle数据库以及数据库的增删改查实例

    初次使用python链接oracle,所以想记录下我遇到的问题,便于向我这样初次尝试的朋友能够快速的配置好环境进入开发环节. 1.首先,python链接oracle数据库需要配置好环境. 我的相关环境 ...

  3. Android学习---数据库的增删改查(sqlite CRUD)

    上一篇文章介绍了sqlite数据库的创建,以及数据的访问,本文将主要介绍数据库的增删改查. 下面直接看代码: MyDBHelper.java(创建数据库,添加一列phone) package com. ...

  4. java jdbc 连接mysql数据库 实现增删改查

    好久没有写博文了,写个简单的东西热热身,分享给大家. jdbc相信大家都不陌生,只要是个搞java的,最初接触j2ee的时候都是要学习这么个东西的,谁叫程序得和数据库打交道呢!而jdbc就是和数据库打 ...

  5. Mybatis学习笔记(二) 之实现数据库的增删改查

    开发环境搭建 mybatis 的开发环境搭建,选择: eclipse j2ee 版本,mysql 5.1 ,jdk 1.7,mybatis3.2.0.jar包.这些软件工具均可以到各自的官方网站上下载 ...

  6. Android中Sqlite数据库进行增删改查

    今天这篇文章写Sqlite数据库,通过一个小案例来完整讲一下数据库常见的CRUD操作. 先对知识点总结: SQLite数据库 轻量级关系型数据库 创建数据库需要使用的api:SQLiteOpenHel ...

  7. Java操作数据库实现"增删改查"

    本文主要讲解JDBC操作数据库    主要实现对MySql数据库的"增删改查" 综合概述: JDBC的常用类和接口 一   DriverManager类 DriverManage类 ...

  8. [译]聊聊C#中的泛型的使用(新手勿入) Seaching TreeVIew WPF 可编辑树Ztree的使用(包括对后台数据库的增删改查) 字段和属性的区别 C# 遍历Dictionary并修改其中的Value 学习笔记——异步 程序员常说的「哈希表」是个什么鬼?

    [译]聊聊C#中的泛型的使用(新手勿入)   写在前面 今天忙里偷闲在浏览外文的时候看到一篇讲C#中泛型的使用的文章,因此加上本人的理解以及四级没过的英语水平斗胆给大伙进行了翻译,当然在翻译的过程中发 ...

  9. 用SpringBoot+MySql+JPA实现对数据库的增删改查和分页

    使用SpringBoot+Mysql+JPA实现对数据库的增删改查和分页      JPA是Java Persistence API的简称,中文名Java持久层API,是JDK 5.0注解或XML描述 ...

随机推荐

  1. 空值排序(oracle/sqlserver)

    oracle认为 null 最大. 升序排列,默认情况下,null值排后面. 降序排序,默认情况下,null值排前面. 改变空值办法: (1)用nvl函数或decode函数将null转换为一特定值 替 ...

  2. var_export函数的使用方法

    var_export() 函数返回关于传递给该函数的变量的结构信息,它和 var_dump() 类似,不同的是其返回的表示是合法的 PHP 代码.var_export必须返回合法的php代码, 也就是 ...

  3. R语言数据处理

    写在前面:数据处理是数据分析与挖掘必不可少的步骤.下面列出一些常用的数据处理操作. 一.类型转换 用class()查看数据的类型,用as.类型名()进行类型转换. > num <- as. ...

  4. HDU 5417 Victor and Machine

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5417 Problem Description Victor has a machine. When t ...

  5. Linux - SSH - Password-less login - generate public key - migrate data without password between two VM servers

    SUMMARY:two server : A , Bsource server : Adestination server : Bthe steps of migrate data from A to ...

  6. hdu 1111 Secret Code

    http://acm.hdu.edu.cn/showproblem.php?pid=1111 复数除法: #include <cstdio> #include <cstring> ...

  7. poj3294 --Life Forms

    Life Forms Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 12483   Accepted: 3501 Descr ...

  8. 转:PHP分页技术的代码和示例

    本文来自:10 Helpful PHP Pagination Scripts For Web Developers 分页是目前在显示大量结果时所采用的最好的方式.有了下面这些代码的帮助,开发人员可以在 ...

  9. pl/sql执行动态sql

    SQL> declare             msql varchar2(200);    begin    loop    msql := 'select * from bfw_test' ...

  10. Controller 中Action 返回值类型 及其 页面跳转的用法

        •Controller 中Action 返回值类型 View – 返回  ViewResult,相当于返回一个View 页面. -------------------------------- ...