本项目是在学习之余写的,主要用来练习MVC+DAO的分层设计思想,项目基于一个简单的XML学生数据库,使用XML作为数据库的原因是其十分的小巧与方便,使用dom4j即可进行方便的解析。因为这段时间课程一直比较密集,在Java相关内容的学习上比较滞后。希望用这个小项目来练一练久矣不写代码的手,也作为研一一个月来的学习小结吧。不废话了,具体内容如下:

项目说明:

本项目提供简单的用户界面(命令行),实现对XML数据库中学生数据的增删改查操作。项目要求使用分层设计思想,为什么要分层?分层可以将不同的代码块分离出来,避免不同功能的代码耦合,为程序扩展和维护提供方便。使用分层,也可以简单化一个系统的设计过程。

DB: students.xml
- Entity: Student 类 (packet: cn.myseu.test.stuMana.entity)
- Dao: StudentDao 类,完成具体的增删改查操作 (packet: cn.myseu.test.stuMana.dao)
- UI: StudentUI 类,实现用户输入操作  (packet: cn.myseu.test.stuMana.ui)
- SMS 类,提供主函数和用户界面  ( packet: cn.myseu.test.stuMana )

数据库如下:student.xml

<?xml version="1.0" encoding="UTF-8"?>

<students>
<student id="133122">
<name>well</name>
<age>22</age>
</student>
</students>

设计Student类完成对数据库中数据的封装

package cn.myseu.test.stuMana.entity;

public class Student {
private String id;
private String name;
private String age; public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getAge() {
return age;
}
public void setAge(String age) {
this.age = age;
} }

设计StudentDao类完成对XML数据库的增删改查操作(这里将公操作进行了抽取,分布为getDocument()和write2xml())

package cn.myseu.test.stuMana.dao;

import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.io.UnsupportedEncodingException; import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter; import cn.myseu.test.stuMana.entity.Student; public class StudentDao { /**
* Add a new student to the database
* @param s
* @return
* @throws Exception
*/
public boolean create(Student s) throws Exception{
boolean flag = false;
if(s!=null){
Document doc = getDocument();
Element root = doc.getRootElement();
Element newElement = root.addElement("student");
newElement.addAttribute("id", s.getId());
newElement.addElement("name").setText(s.getName());
newElement.addElement("age").setText(s.getAge());
write2xml(doc);
flag = true;
}
return flag;
} /**
* delete a student from the xml-database
* @param id the student_id you want to delete
* @return
* @throws Exception
*/
public boolean delete(String id) throws Exception{
boolean flag = false;
Document doc = getDocument();
String xpath = "//student[@id='"+id+"']";
Element element = (Element) doc.selectSingleNode(xpath);
if(element!=null){
element.getParent().remove(element);
write2xml(doc);
flag = true;
}else
System.out.println("ID is not existed!");
return flag;
} /**
* search the information of a specified student
* @param id
* @throws Exception
*/
public void check(String id) throws Exception{
Document doc = getDocument();
String xpath = "//student[@id='"+id+"']";
Element element = (Element) doc.selectSingleNode(xpath);
if(element!=null){
System.out.println("stu_id:"+element.attributeValue("id"));
System.out.println("stu_name:"+element.elementText("name"));
System.out.println("stu_age:"+element.elementText("age"));
}else
System.out.println("ID is not existed!");
} /**
* update a specified student
* @param s
* @return
* @throws Exception
*/
public boolean update(Student s) throws Exception{
boolean flag = false;
Document doc = getDocument();
String xpath = "//student[@id='"+s.getId()+"']";
Element element = (Element) doc.selectSingleNode(xpath);
if(element!=null){
element.element("name").setText(s.getName());
element.element("age").setText(s.getAge());
write2xml(doc);
flag = true;
}
else
System.out.println("ID is not existed!");
return flag;
} /*
* the public function
* getDocument() & write2xml
*/
private void write2xml(Document doc) throws FileNotFoundException,
UnsupportedEncodingException, IOException {
OutputStream os = new FileOutputStream(new File("src/cn/myseu/test/stuMana/db/students.xml"));
OutputFormat format = OutputFormat.createPrettyPrint();
XMLWriter xw = new XMLWriter(os,format);
xw.write(doc);
xw.close();
} private Document getDocument() throws DocumentException {
SAXReader sr = new SAXReader();
Document doc = sr.read(new File("src/cn/myseu/test/stuMana/db/students.xml"));
return doc;
} }

设计StudentUI类,完成系统功能:

package cn.myseu.test.stuMana.ui;

import java.util.Scanner;

import cn.myseu.test.stuMana.dao.StudentDao;
import cn.myseu.test.stuMana.entity.Student; public class StudentUI { public void create() throws Exception{
Scanner scanner = new Scanner(System.in);
System.out.println("Input stu_id:");
String id = scanner.nextLine();
System.out.println("Input stu_name:");
String name = scanner.nextLine();
System.out.println("Input stu_age:");
String age = scanner.nextLine(); Student s = new Student();
s.setId(id);
s.setName(name);
s.setAge(age); StudentDao stuDao = new StudentDao();
boolean flag = stuDao.create(s);
if(flag)
System.out.println("Your create operation is successful!");
else
System.out.println("Your create operation is failed!");
} public void delete() throws Exception{
Scanner scanner = new Scanner(System.in);
System.out.println("Input the stu_id of the student who you want to delete:");
String id = scanner.nextLine();
StudentDao stuDao = new StudentDao();
boolean flag = stuDao.delete(id);
if(flag)
System.out.println("Your delete operation is successful!");
else
System.out.println("Your delete operation is failed!");
} public void check() throws Exception{
Scanner scanner = new Scanner(System.in);
System.out.println("Input the stu_id of the student who you want to get:");
String id = scanner.nextLine();
StudentDao stuDao = new StudentDao();
stuDao.check(id);
} public void update() throws Exception{
Scanner scanner = new Scanner(System.in);
System.out.println("Input the stu_id of the student who you want to update:");
String id = scanner.nextLine();
System.out.println("The new name:");
String name = scanner.nextLine();
System.out.println("The new age:");
String age = scanner.nextLine();
Student s = new Student();
s.setId(id);
s.setAge(age);
s.setName(name);
StudentDao stuDao = new StudentDao();
boolean flag = stuDao.update(s);
if(flag)
System.out.println("Your delete operation is successful!");
else
System.out.println("Your delete operation is failed!");
}
}

设计SMS类,提供系统菜单和用户输入输出:

package cn.myseu.test.stuMana;

import java.util.Scanner;

import cn.myseu.test.stuMana.ui.StudentUI;

public class SMS {
public static void main(String[] args) throws Exception {
System.out.println("========================================");
System.out.println("====== Student Management System =======");
System.out.println("====== Version 1.0 Author:Well =======");
System.out.println("========================================");
System.out.println("1.create a new student");
System.out.println("2.delete a student from the system");
System.out.println("3.search information of a student");
System.out.println("4.update information of a student");
System.out.println("========================================");
System.out.println("Please input your operation number:"); Scanner scanner = new Scanner(System.in);
StudentUI sui = new StudentUI(); int num = Integer.parseInt(scanner.nextLine());
switch(num){
case 1:
sui.create();break;
case 2:
sui.delete();break;
case 3:
sui.check();break;
case 4:
sui.update();break;
default:
System.out.println("You should input form [1-4]");;break;
}
}
}

最后,简单而丑陋的系统运行界面如下:

最后,这个简单丑陋的系统仅仅是练习和复习相关的知识所用。但我认为也是一个非常简单的分层设计思想的很好的体现。系统简单容易上手。大概用了3个小时左右设计完成。

基于XML数据库的学生信息管理系统的设计与实现的更多相关文章

  1. 基于JSP+Servlet的学生信息管理系统

    JavaWeb期末项目,一个基于JSP和Servlet的学生信息管理系统实现,前端用了bootstrap和一些自定义的css样式,数据库用了mysql 传送门: GitHub 实现功能 登录(教师, ...

  2. Linux下基于shell脚本实现学生信息管理系统

    #该管理系统是参考两位博主(时间有点远了,我忘了,请博主看到后联系我)后自行修改添加的.登录过程还有很多不完善,我就抛砖引玉啦. 废话不多,直接上码! #!/bin/bash# 学生管理系统# @ve ...

  3. 基于数据库MySQL的简易学生信息管理系统

    通过这几天学习Mysql数据库,对其也有了基本的了解,为了加深印象,于是就写了一个最简易的学生信息管理系统. 一:基本要求 1.通过已知用户名和密码进行登录: 2.可以显示菜单: 3.可以随时插入学生 ...

  4. 基于Spring MVC + Spring + MyBatis的【学生信息管理系统】

    资源下载:https://download.csdn.net/download/weixin_44893902/45603211 练习点设计: 模糊查询.删除.新增 一.语言和环境 实现语言:JAVA ...

  5. asp.net+sql数据库学生信息管理系统

    一款学生信息管理系统送给大家. 功能部分: 1.教师管理(添加,修改,删除,查看) 2.学生管理(添加,修改,删除,查看) 3.班级管理(添加,修改,删除,查看) 4.学生成绩管理(添加,修改,删除, ...

  6. 学生信息管理系统总结——student数据库中表关系分析

    说到关系,那就不得不提两个东西: 1.E-R图,也称实体-联系图(Entity Relationship Diagram),提供了表示实体类型.属性和联系的方法,用来描述现实世界的概念模型 2.关系模 ...

  7. 基于数组或链表的学生信息管理系统(小学期C语言程序实训)

    1.基于数组的学生信息管理系统 实验内容: 编写并调试程序,实现学校各专业班级学生信息的管理.定义学生信息的结构体类型,包括:学号.姓名.专业.班级.3门成绩. 实验要求: (1) main函数:以菜 ...

  8. Android(java)学习笔记195:学生信息管理系统案例(SQLite + ListView)

    1.首先说明一个知识点,通常我们显示布局文件xml都是如下: setContentView(R.layout.activity_main): 其实每一个xml布局文件就好像一个气球,我们可以使用Vie ...

  9. Android(java)学习笔记188:学生信息管理系统案例(SQLite + ListView)

    1.首先说明一个知识点,通常我们显示布局文件xml都是如下: setContentView(R.layout.activity_main): 其实每一个xml布局文件就好像一个气球,我们可以使用Vie ...

随机推荐

  1. Servlet课程0426(九)Servlet服务器端创建Cookie和客户端读取Cookie

    服务器端创建Cookie: Win7默认Cookie位置 C:\Users\Administrator\AppData\Roaming\Microsoft\Windows\Cookies Cookie ...

  2. C++不同进制整数

    在C++的整数常量中,整数分为十进制整数.八进制整数和十六进制整数. 那给出一个整型常量怎样区分是何种进制呢?/给出一个整型常量,如100,默认是十进制数,如果在该数前加0,如0100,则此数表示为八 ...

  3. 性能优化工具 MVC Mini Profiler

    性能优化工具 MVC Mini Profiler   MVC MiniProfiler是Stack Overflow团队设计的一款对ASP.NET MVC.WebForm 以及WCF 的性能分析的小程 ...

  4. [译]15个关于Chrome的开发必备小技巧

    谷歌Chrome,是当前最流行且被众多web开发人员使用的浏览器.最快六周就更新发布一次以及伴随着它不断强大的开发组件,使得Chrome成为你必备的开发工具.例如,在线编辑CSS,console以及d ...

  5. node.js模块之util模块

    util提供了各种使用的工具.require('util') to access them. Util.format(format,[..]) Returns a formatted string u ...

  6. 新LNMP环境,但是SESSION跨页面或者刷新 session丢失

    唠叨:本地WAMP做了一个微信项目,一切OK,昨天需要在LINUX架设一套LNMP环境.但是,在架设代码的时候,登录总是不成功~~~ 最终解决:权限 其实,作为一个程序猿,只要涉及到服务器内容,都应该 ...

  7. 获取View的高度宽度,屏幕参数,状态栏高度

    基础 各区域示例,注意绿色,紫色,橙色区域 注意: 在onCreate只是对象的初始创建过程,这时并没有draw,这时view.getHeight返回0,可在onStart里用getHeight等. ...

  8. 在C++中调用DLL中的函数

    如何在C++中调用DLL中的函数 应用程序使用DLL可以采用两种方式:一种是隐式链接,另一种是显式链接.在使用DLL之前首先要知道DLL中函数的结构信息.Visual C++6.0在VC\bin目录下 ...

  9. 【HDOJ】3828 A + B problem

    显然需要贪心,重叠越长越好,这样最终的串长尽可能短.需要注意的是,不要考虑中间结果,显然是个状态dp.先做预处理去重,然后求任意一对串的公共长度. /* 3828 */ #include <io ...

  10. UVa 1641 ASCII Area

    题意: 就是用一个字符矩阵代表一个闭合的阴影部分,然后求阴影部分的面积. 分析: 一个'/'和'\'字符都代表半个小方块的面积. 关键就是判断'.'是否属于阴影部分,这才是本题的关键. 从第一列开始, ...