1.xml文件:

 <?xml version="1.0" encoding="UTF-8"?><Students>
<student id="2">
<name>ttt</name>
<age>44</age>
</student>
<student id="3">
<name>linda2</name>
<age>22</age>
</student>
<student id="4">
<name>linda3</name>
<age>23</age>
</student>
<student id="5">
<name>jack</name>
<age>2</age>
</student>
<student id="1">
<name>yyh1</name>
<age>22</age>
</student>
</Students>

2.Java代码

 import java.io.File;
import java.io.IOException;
import java.util.Scanner; import javax.xml.parsers.ParserConfigurationException;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerConfigurationException;
import javax.xml.transform.TransformerException;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.TransformerFactoryConfigurationError;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult; import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NodeList;
import org.w3c.dom.Text;
import org.xml.sax.SAXException; //在学生管理系统里面,学生的学号是唯一的,姓名有可能重复
public class StudentManager {
public static void main(String[] args) {
try {
Document doc = Domutils.getDoc(new File("xml文件的相对路径"));
Scanner input = new Scanner(System.in);
System.out.println("欢迎来到学生管理系统\n\n\n请输入你要进行什么操作是:\n1.添加学生信息\n2.删除学生信息\n3.修改学生信息\n(请输入前边的序号)");
int num = input.nextInt();
if(num == 1) {
addStudent(doc);
}else if(num == 2) {
delStudent(doc);
}else if(num == 3) {
updStudent(doc);
}
} catch (SAXException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} catch (ParserConfigurationException e) {
e.printStackTrace();
}
}
//修改学生信息
private static void updStudent(Document doc) {
Element updStudent = null;
Scanner input = new Scanner(System.in);
System.out.println("请输入你要修改的学生的学号:");
String studentid = input.nextLine();
System.out.println("请输入新学生的姓名:");
String newName = input.nextLine();
System.out.println("请输入新学生的年龄:");
String newAge = input.nextLine(); //将每一个学生的列出来,for循环判断你要修改信息的学生是哪一个
NodeList list = doc.getElementsByTagName("student");
for(int i = 0; i <list.getLength(); i++) {
if(studentid.equals(list.item(i).getAttributes().getNamedItem("id").getNodeValue())){
updStudent = (Element) doc.getElementsByTagName("student").item(i).getFirstChild().getParentNode();
//对学生的name属性进行赋新值
updStudent.getElementsByTagName("name").item(i).getFirstChild().setNodeValue(newName);
//对学生的age 属性赋新值
updStudent.getElementsByTagName("age").item(i).getFirstChild().setNodeValue(newAge); }else{
break;
}
}
//找出根元素,将修改后的元素持久化到文件
Element root = doc.getDocumentElement();
transform(root);
System.out.println(updStudent);
}
//删除学生信息
private static void delStudent(Document doc) {
Scanner input = new Scanner(System.in);
//输入你要删除的学生的 学号
System.out.println("请输入要删除学生的学号:");
String studentid = input.nextLine();
Element root = doc.getDocumentElement(); //将学生列成一个表,进行遍历,找对应学号的学生进行删除
NodeList list = doc.getElementsByTagName("student");
for(int i = 0; i < list.getLength(); i++) {
if((studentid).equals(list.item(i).getAttributes().getNamedItem("id").getNodeValue())){
Element delStudent = (Element) doc.getElementsByTagName("student").item(i).getFirstChild().getParentNode();
root.removeChild(delStudent);
break;
}else {
System.out.println("没有该学生");
break;
}
}
//持久化到文件
transform(root);
} //添加学生信息
private static void addStudent(Document doc) {
// System.out.println(doc.getElementsByTagName("student").item(1).getAttributes().getNamedItem("id").getNodeValue());
Element root = doc.getDocumentElement();
//从控制台输入
Scanner input = new Scanner(System.in);
System.out.println("请输入学生的序号:id = "); //将学生放到一个列表里面,看我们要添加的学生的学号里面是否已经有了,如果有,需要将新加入的学生的学号改一下
NodeList list = doc.getElementsByTagName("student");
String studentid = input.nextLine();
for(int i = 0; i < list.getLength(); i++) {
if(studentid.equals(list.item(i).getAttributes().getNamedItem("id").getNodeValue())){
System.out.println("该序号学生表里面已经存在,请重新输入一个新的序号:");
studentid = input.nextLine();
}else {
break;
}
} System.out.println("请输入要添加学生的姓名:name = ");
String name_value = input.nextLine();
System.out.println("请输入要添加学生的年龄:age = ");
String age_value = input.nextLine(); //创建节点
Element student = doc.createElement("student");
Element name = doc.createElement("name");
Element age = doc.createElement("age");
Text namText = doc.createTextNode(name_value);
Text ageText = doc.createTextNode(age_value);
//关联节点之间的关系
root.appendChild(student);
student.appendChild(name);
student.appendChild(age);
student.setAttribute("id", studentid);
name.appendChild(namText);
age.appendChild(ageText);
//持久化到文件
transform(root); }
//持久化到文件的方法
private static void transform(Element root)
throws TransformerFactoryConfigurationError {
TransformerFactory factory = TransformerFactory.newInstance();
try {
Transformer tf = factory.newTransformer();
tf.transform(new DOMSource(root), new StreamResult(new File("src/com/briup/dom/student.xml")));
} catch (TransformerConfigurationException e) {
e.printStackTrace();
} catch (TransformerException e) {
e.printStackTrace();
}
}
}

2.Dom解析文件(将获取解析文件的部分封装起来)

import java.io.File;
import java.io.IOException;
import java.nio.file.attribute.AclEntry.Builder; import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException; import org.w3c.dom.Document;
import org.xml.sax.SAXException; public class Domutils {
public static Document getDoc(File file) throws SAXException, IOException, ParserConfigurationException {
      //获取工厂模式
DocumentBuilderFactory factory =
DocumentBuilderFactory.newInstance();
        //获取builder对象
DocumentBuilder builder = factory.newDocumentBuilder();
        //将要解析文件加载成一个树状文件,开始解析
Document document = builder.parse(file);
return document;
}
}

将xml文件作为一个小的数据库,进行学生的增删改查的更多相关文章

  1. MySQL数据库之表的增删改查

    目录 MySQL数据库之表的增删改查 1 引言 2 创建表 3 删除表 4 修改表 5 查看表 6 复制表 MySQL数据库之表的增删改查 1 引言 1.MySQL数据库中,数据库database就是 ...

  2. sqlite数据库操作详细介绍 增删改查,游标

    sqlite数据库操作详细介绍 增删改查,游标     本文来源于www.ifyao.com禁止转载!www.ifyao.com Source code     package com.example ...

  3. Java学生信息增删改查(并没用数据库)

    一个泛型的应用,Java版本增删改查,写的简陋,望批评指正 2016-07-02 很久前写的一个程序了.拿出来存一下,不是为了展示啥,自己用的时候还可以看看.写的很粗糙. import java.io ...

  4. Delphi - cxGrid连接Oracle数据库 实现数据的增删改查

    cxGrid连接Oracle数据库 实现数据的增删改查 cxGrid连接Oracle数据库 1:通过OraSession连接数据库.OraDataSet实现OraSession和OraDataSour ...

  5. 使用JDBC分别利用Statement和PreparedStatement来对MySQL数据库进行简单的增删改查以及SQL注入的原理

    一.MySQL数据库的下载及安装 https://www.mysql.com/ 点击DOWNLOADS,拉到页面底部,找到MySQL Community(GPL)Downloads,点击 选择下图中的 ...

  6. MVC设计模式((javaWEB)在数据库连接池下,实现对数据库中的数据增删改查操作)

    设计功能的实现: ----没有业务层,直接由Servlet调用DAO,所以也没有事务操作,所以从DAO中直接获取connection对象 ----采用MVC设计模式 ----采用到的技术 .MVC设计 ...

  7. MVC模式:实现数据库中数据的增删改查功能

    *.数据库连接池c3p0,连接mysql数据库: *.Jquery使用,删除时跳出框,确定是否要删除: *.使用EL和JSTL,简化在jsp页面中插入的java语言 1.连接数据库 (1)导入连接数据 ...

  8. 数据库中简单的增删改查(CRUD)

    一切都是基于数据,而对数据的管理都离不开数据库.最近学到数据库的简单操作,所以写下这篇文章,总结一下学习到的知识.浅陋之处,多多见谅. 补充一下:一直弄不清SQL Server,Mysql ,以及Or ...

  9. MongoDB 数据库的概念以增删改查

    1,MongoDB概念解析: Mongo数据库基本概念是文档,集合,数据库,下表给予介绍 SQL术语概念 MongoDB术语概念 解释/说明 database database 数据库 table c ...

随机推荐

  1. linux程序设计1

    a.out 的意思是 assembler output,即汇编输出. C语言的头文件一般位于 /usr/include/ 目录下,而依赖于特定 Linux 版本的头文件通常可在目录 /usr/incl ...

  2. jQuery1.9.1源码分析--数据缓存Data模块

    jQuery1.9.1源码分析--数据缓存Data模块 阅读目录 jQuery API中Data的基本使用方法介绍 jQuery.acceptData(elem)源码分析 jQuery.data(el ...

  3. eclipse如何导入java项目文件

    平时下载到项目时,希望能够导入到eclipse中使用.但有些项目不能直接导入,需要做转换. 打开源文件目录,查询如下: 如果目录中包含pom.xml文件,则说明该项目由Maven构建的,参考以下 如何 ...

  4. Mac Pro 编译安装 Nginx 1.8.1

    #下载相关源码包,统一放到 /usr/local/src 目录下: http://nginx.org/download/nginx-1.8.1.tar.gz http://zlib.net/zlib- ...

  5. Inno Setup制作应用程序安装包

    我最近写了一个MFC应用程序,想发给其他的小伙伴玩一玩,直接发了个exe文件过去,结果发现小伙伴那边打不开.原来这个exe文件虽然是MFC静态编译的,但是还依赖了其他几个.dll文件,需要把这几个dl ...

  6. nginx 虚拟主机

    基于域名的虚拟主机 创建站点目录 [root@nginx conf]# cd /usr/local/nginx/html/ [root@nginx html]# pwd /usr/local/ngin ...

  7. 为 Github 创造 Integration

    导读 现在你可以从我们的 集成件目录里面找到更多工具.这个目录目前有超过 15 个分类 — 从 API 管理 到 应用监控, Github 的集成件可以支持您的开发周期的每一个阶段. 我们邀请了具有不 ...

  8. 操作PDF文件的关键技术点

    一个PDF文档从大到小可以分成如下几个要素:文档.章节.小节.段落.表格.列表. com.lowagie.text.Document表示PDF文档.必须为它创建一个PDF写入器,即com.lowagi ...

  9. [codeforces 360]A. Levko and Array Recovery

    [codeforces 360]A. Levko and Array Recovery 试题描述 Levko loves array a1, a2, ... , an, consisting of i ...

  10. 剑指Offer 变态跳台阶

    题目描述 一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级.求该青蛙跳上一个n级的台阶总共有多少种跳法.   其实就是斐波那契数列问题. 假设f(n)是n个台阶跳的次数. f(1) = ...