将xml文件作为一个小的数据库,进行学生的增删改查
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文件作为一个小的数据库,进行学生的增删改查的更多相关文章
- MySQL数据库之表的增删改查
目录 MySQL数据库之表的增删改查 1 引言 2 创建表 3 删除表 4 修改表 5 查看表 6 复制表 MySQL数据库之表的增删改查 1 引言 1.MySQL数据库中,数据库database就是 ...
- sqlite数据库操作详细介绍 增删改查,游标
sqlite数据库操作详细介绍 增删改查,游标 本文来源于www.ifyao.com禁止转载!www.ifyao.com Source code package com.example ...
- Java学生信息增删改查(并没用数据库)
一个泛型的应用,Java版本增删改查,写的简陋,望批评指正 2016-07-02 很久前写的一个程序了.拿出来存一下,不是为了展示啥,自己用的时候还可以看看.写的很粗糙. import java.io ...
- Delphi - cxGrid连接Oracle数据库 实现数据的增删改查
cxGrid连接Oracle数据库 实现数据的增删改查 cxGrid连接Oracle数据库 1:通过OraSession连接数据库.OraDataSet实现OraSession和OraDataSour ...
- 使用JDBC分别利用Statement和PreparedStatement来对MySQL数据库进行简单的增删改查以及SQL注入的原理
一.MySQL数据库的下载及安装 https://www.mysql.com/ 点击DOWNLOADS,拉到页面底部,找到MySQL Community(GPL)Downloads,点击 选择下图中的 ...
- MVC设计模式((javaWEB)在数据库连接池下,实现对数据库中的数据增删改查操作)
设计功能的实现: ----没有业务层,直接由Servlet调用DAO,所以也没有事务操作,所以从DAO中直接获取connection对象 ----采用MVC设计模式 ----采用到的技术 .MVC设计 ...
- MVC模式:实现数据库中数据的增删改查功能
*.数据库连接池c3p0,连接mysql数据库: *.Jquery使用,删除时跳出框,确定是否要删除: *.使用EL和JSTL,简化在jsp页面中插入的java语言 1.连接数据库 (1)导入连接数据 ...
- 数据库中简单的增删改查(CRUD)
一切都是基于数据,而对数据的管理都离不开数据库.最近学到数据库的简单操作,所以写下这篇文章,总结一下学习到的知识.浅陋之处,多多见谅. 补充一下:一直弄不清SQL Server,Mysql ,以及Or ...
- MongoDB 数据库的概念以增删改查
1,MongoDB概念解析: Mongo数据库基本概念是文档,集合,数据库,下表给予介绍 SQL术语概念 MongoDB术语概念 解释/说明 database database 数据库 table c ...
随机推荐
- javascript简单的认识下return语句+2015的总结+2016的展望
好久没更新博客了...自从有了mac之后世界变得简单了...日常么,除了研究代码,看别人的代码,写自己的代码.就那样.... 吐槽点:window配个nodejs的环境花了九头牛两只老虎的力气,mac ...
- 【CISP笔记】数据库及应用安全
数据库安全特性检查工具美国应用安全公司的App Detective英国下一代软件公司的NGS SQuirrel 常见应用安全威胁 网络层面拒绝服务.电子欺骗.嗅探.……系统层面Web服务漏洞.配置错误 ...
- 如何催促Apple进行App审核
为什么提交给 App Store 的应用进入"审核(In Review)"状态后, 仍然可能会等待好多天的时间 ? 不过你也可以通过催促Apple进行App审核来缩短这个时间.以下 ...
- iSCSI配置流程
Windows群集两个节点:分别在SQL01和SQL02设置连接共享磁盘: 此前已经在存储服务器通过StarWind创建了三个虚拟磁盘:Quemon+data+backup:starwind安装请参考 ...
- PHP基础 之 基本数据类型练习
<h3>PHP基础练习</h3> <?php echo "<h4>常量</h4>"; //定义:一般大写,使用下划线间隔 de ...
- 用数组求Fibonacci数列
#include<stdio.h>int main(){ int a[20]={1,1}; int n=2,i; for(n=2;n<20;n++) ...
- linux下svn命令使用大全
最近经常使用svn进行代码管理,这些命令老是记不住,得经常上网查,终于找了一个linux下svn命令使用大全:1.将文件checkout到本地目录 svn checkout path(path是服务器 ...
- FineUI第十八天---表格之事件的处理
表格之事件的处理: 1.事件参数: GridPageEventArgs:表格分页事件参数,对应onPageIndexChange事件. NewPageIndex:新页面的索引 GridSortEven ...
- Android本地数据存储之SQLite关系型数据库 ——SQLiteDatabase
数据库的创建,获取,执行sql语句: 框架搭建:dao 思考: 1.数据库保存在哪里? 2.如何创建数据库?如何创建表? 3.如何更新数据库?如何更改表的列数据? 4.如何获取数据库? 5.如何修改数 ...
- HDU 5014 Number Sequence(位运算)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5014 解题报告:西安网赛的题,当时想到一半,只想到从大的开始匹配,做异或运算得到对应的b[i],但是少 ...