热门标签 | HotTags
当前位置:  开发笔记 > Android > 正文

用xml代替数据库的一个小项目

Student.javapackagecom.bean;publicclassStudent{privateStringexamid;privateStringidcard;privateStringname;privateStringlocation;privatedoublegrade;publicStringgetExamid(){returnexamid;}publicvoidsetExamid(Stri

Student.java package com.bean; public class Student { private String examid; private String idcard; private String name; private String location; private double grade; public String getExamid() { return examid; } public void setExamid(Stri

Student.java

package com.bean;

public class Student {

private String examid;
private String idcard;
private String name;
private String location;
private double grade;
public String getExamid() {
return examid;
}
public void setExamid(String examid) {
this.examid = examid;
}
public String getIdcard() {
return idcard;
}
public void setIdcard(String idcard) {
this.idcard = idcard;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getLocation() {
return location;
}
public void setLocation(String location) {
this.location = location;
}
public double getGrade() {
return grade;
}
public void setGrade(double grade) {
this.grade = grade;
}
}
StudentUtil.java

package com.utils;

import java.io.File;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;

import org.w3c.dom.Document;
import org.w3c.dom.Element;

import com.bean.Student;

public class StudentUtil {
private static final String file = "src/student.xml";
// 获得Document文件的方法
public static Document getDocument() {
try {
DocumentBuilderFactory factory = DocumentBuilderFactory
.newInstance();
DocumentBuilder db = factory.newDocumentBuilder();
return db.parse(file);
} catch (Exception e) {
throw new RuntimeException(e);
}
}

// 写入xml文件的方法
public static void writeXml(Document document) {
try {
Transformer tf = TransformerFactory.newInstance().newTransformer();
tf.transform(new DOMSource(document),new StreamResult(new File(file)));
} catch (Exception e) {
throw new RuntimeException(e);
}
}
//把节点的值封装到bean中
public static Student nodeBean(Element e,Class c){
try {
Student s = c.newInstance();
s.setExamid(e.getAttribute("examid"));
s.setIdcard(e.getAttribute("idcard"));
s.setName(e.getElementsByTagName("name").item(0).getTextContent());
s.setLocation(e.getElementsByTagName("location").item(0).getTextContent());
s.setGrade(Double.parseDouble(e.getElementsByTagName("grade").item(0).getTextContent()));
return s;
} catch (Exception e1) {
throw new RuntimeException(e1);
}
}
}
StudentDao.java

package com.dao;

import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NodeList;

import com.bean.Student;
import com.utils.StudentUtil;

public class StudentDao {

/**
* @param args
*/
//增加学生
public void insertS(Student s){
Document document = StudentUtil.getDocument();
//创建sutudet节点
Element rootNode = document.createElement("student");
//给sutudet节点设置属性
rootNode.setAttribute("examid",s.getExamid());
rootNode.setAttribute("idcard",s.getIdcard());
//创建sutudet子节点
Element name = document.createElement("name");
Element location = document.createElement("location");
Element grade = document.createElement("grade");
//给sutudet子节点设值
name.setTextContent(s.getName());
location.setTextContent(s.getLocation());
grade.setTextContent(s.getGrade()+"");
//把sutudet子节点追加到跟节点后
rootNode.appendChild(name);
rootNode.appendChild(location);
rootNode.appendChild(grade);
//把sutudet节点加入到根节点
document.getElementsByTagName("exam").item(0).appendChild(rootNode);
//写入到xml文件
StudentUtil.writeXml(document);
}
//删除学生
public void deleteS(String name){
Document document = StudentUtil.getDocument();
NodeList list = document.getElementsByTagName("name");
for(int i=0;i Element node = (Element) list.item(i);
if(node.getTextContent().equals(name)){
node.getParentNode().getParentNode().removeChild(node.getParentNode());
StudentUtil.writeXml(document);
return;
}
}
}
//查询学生
public Student queryS(String examid){
Document document = StudentUtil.getDocument();
NodeList list = document.getElementsByTagName("student");
for(int i=0;i Element studentNode = (Element) list.item(i);
String value = studentNode.getAttribute("examid");
if(value.equals(examid)){
Student student = StudentUtil.nodeBean(studentNode, Student.class);
return student;
}
}
return null;
}

}
StudentTest.java

package com.juil;

import org.junit.Test;

import com.bean.Student;
import com.dao.StudentDao;

public class StudentTest {

/**
* @param args
*/
private Student student = new Student();
private StudentDao dao = new StudentDao();
//测试添加学生
@Test
public void insertTest(){
student.setExamid("12345");
student.setIdcard("1122");
student.setName("杨凯");
student.setLocation("邢台");
student.setGrade(100);
dao.insertS(student);
}
@Test
public void queryTest(){
dao.queryS("111");
System.out.println(student.getName());
}
@Test
public void deleteTest(){
dao.deleteS("李小三");
}
}
Main.java

package com.main;

import java.io.BufferedReader;
import java.io.InputStreamReader;

import com.bean.Student;
import com.dao.StudentDao;

public class Main {

public static void main(String[] args) {

while (true) {
try {
System.out.println("添加学生(a) 查找学生(b) 删除学生(c) 退出(quit)");
System.out.print("请选择操作的类型:");

BufferedReader br = new BufferedReader(new InputStreamReader(
System.in));
String type = br.readLine();

if ("quit".equalsIgnoreCase(type)) {
return;
}
if (!type.matches("[abcABC]")) {
System.out.println("请输入正确的操作类型!!");
continue;
}

if (type.equalsIgnoreCase("a")) {
// 进入添加学生环节
try {
System.out.print("请输入学生姓名:");
String name = br.readLine();
System.out.print("请输入学生准考证号:");
String examid = br.readLine();
System.out.print("请输入学生身份证号:");
String idcard = br.readLine();
System.out.print("请输入学生所在地:");
String location = br.readLine();
System.out.print("请输入学生成绩:");
double grade = Double.parseDouble(br.readLine());

Student s = new Student();
s.setExamid(examid);
s.setGrade(grade);
s.setIdcard(idcard);
s.setLocation(location);
s.setName(name);

StudentDao dao = new StudentDao();
dao.insertS(s);
System.out.println("数据录入成功!!");
} catch (Exception e) {
System.out.println("由于未知原因,录入失败!!");
}

} else if (type.equalsIgnoreCase("b")) {
//进入查找环节
try {
System.out.print("请输入学生准考证号:");
String examid = br.readLine();
Student s = new Student();
s.setExamid(examid);
StudentDao dao = new StudentDao();
s = dao.queryS(examid);
System.out.println("名字 :" + s.getName());
System.out.println("准考证号: " + s.getExamid());
System.out.println("学号: " + s.getIdcard());
System.out.println("所在地: " + s.getLocation());
System.out.println("分数: " + s.getGrade());
System.out.println("查找成功!!!");
} catch (RuntimeException e) {
System.out.println("由于未知原因,查询失败!!");
}
} else {
//进入删除环节
try {
System.out.print("请输入学生姓名:");
String name = br.readLine();
Student s = new Student();
s.setName(name);
StudentDao dao = new StudentDao();
dao.deleteS(name);
System.out.println("删除成功!!!");
} catch (RuntimeException e) {
System.out.println("由于未知原因,删除失败!!");
}
}

} catch (Exception e) {
System.out.println("系统出错了,请重新再试!!!");
}
}
}

}
student.xml



张三
沈阳
89


李四
大连
97


xxx
北京
45.0


杨凯
邢台
100.0


推荐阅读
  • 本文详细介绍了 RosPack 类的功能和用法,探讨了其在 ROS 系统中的重要作用。RosPack 类提供了类似于终端命令 rospack 的功能,能够方便地查询和管理 ROS 包的相关信息。 ... [详细]
  • 本文探讨了如何使用自增和自减运算符遍历二维数组中的元素。通过实例详细解释了指针与二维数组结合使用的正确方法,并解答了常见的错误用法。 ... [详细]
  • Python处理Word文档的高效技巧
    本文详细介绍了如何使用Python处理Word文档,涵盖从基础操作到高级功能的各种技巧。我们将探讨如何生成文档、定义样式、提取表格数据以及处理超链接和图片等内容。 ... [详细]
  • 本文介绍如何使用 Android 的 Canvas 和 View 组件创建一个简单的绘图板应用程序,支持触摸绘画和保存图片功能。 ... [详细]
  • 本文介绍了如何利用 Spring Boot 和 Groovy 构建一个灵活且可扩展的动态计算引擎,以满足钱包应用中类似余额宝功能的推广需求。我们将探讨不同的设计方案,并最终选择最适合的技术栈来实现这一目标。 ... [详细]
  • 采用IKE方式建立IPsec安全隧道
    一、【组网和实验环境】按如上的接口ip先作配置,再作ipsec的相关配置,配置文本见文章最后本文实验采用的交换机是H3C模拟器,下载地址如 ... [详细]
  • 在进行QT交叉编译时,可能会遇到与目标架构不匹配的宏定义问题。例如,当为ARM或MIPS架构编译时,需要确保使用正确的宏(如QT_ARCH_ARM或QT_ARCH_MIPS),而不是默认的QT_ARCH_I386。本文将详细介绍如何正确配置编译环境以避免此类错误。 ... [详细]
  • 基于机器学习的人脸识别系统实现
    本文介绍了一种使用机器学习技术构建人脸识别系统的实践案例。通过结合Python编程语言和深度学习框架,详细展示了从数据预处理到模型训练的完整流程,并提供了代码示例。 ... [详细]
  • 本文详细介绍了如何使用 PHP 接收并处理微信支付的回调结果,确保支付通知能够被正确接收和响应。 ... [详细]
  • 我有一个SpringRestController,它处理API调用的版本1。继承在SpringRestControllerpackagerest.v1;RestCon ... [详细]
  • 简化报表生成:EasyReport工具的全面解析
    本文详细介绍了EasyReport,一个易于使用的开源Web报表工具。该工具支持Hadoop、HBase及多种关系型数据库,能够将SQL查询结果转换为HTML表格,并提供Excel导出、图表显示和表头冻结等功能。 ... [详细]
  • 理解UML的重要性及其应用
    探讨为什么大多数开发人员难以成为架构师,介绍从现实世界到业务模型的抽象过程,并详细解释UML在软件设计中的关键作用。 ... [详细]
  • ABBYY FineReader:高效PDF转换、精准OCR识别与文档对比工具
    在处理PDF转换和OCR识别时,您是否遇到过格式混乱、识别率低或图表无法正常识别的问题?ABBYY FineReader以其强大的功能和高精度的识别技术,完美解决这些问题,帮助您轻松找到最终版文档。 ... [详细]
  • 深入解析SpringMVC核心组件:DispatcherServlet的工作原理
    本文详细探讨了SpringMVC的核心组件——DispatcherServlet的运作机制,旨在帮助有一定Java和Spring基础的开发人员理解HTTP请求是如何被映射到Controller并执行的。文章将解答以下问题:1. HTTP请求如何映射到Controller;2. Controller是如何被执行的。 ... [详细]
  • 深入解析Spring启动过程
    本文详细介绍了Spring框架的启动流程,帮助开发者理解其内部机制。通过具体示例和代码片段,解释了Bean定义、工厂类、读取器以及条件评估等关键概念,使读者能够更全面地掌握Spring的初始化过程。 ... [详细]
author-avatar
郭建将_683
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有