用基本数据结构修改后的学生信息管理系统(增删改查)

package com.xt.student.system;

//创建学生类存放信息

public class Student {
//声明变量
private String stuNo;

private String stuName;

private String gender;

private int age;

private int score;

//对变量进行封装

public String getStuNo() {
return stuNo;
}

public void setStuNo(String stuNo) {
this.stuNo = stuNo;
}

public String getStuName() {
return stuName;
}

public void setStuName(String stuName) {
this.stuName = stuName;
}

public String getGender() {
return gender;
}

public void setGender(String gender) {
this.gender = gender;
}

public int getAge() {
return age;
}

public void setAge(int age) {
this.age = age;
}

public int getScore() {
return score;
}

public void setScore(int score) {
this.score = score;
}
//修改toString()方法来输出学生信息,否则输出的为学生信息存储地址
public String toString() {
return "| " + stuNo + " | " + stuName + " | " + gender + " | " + age + " | " + score + " | ";
}

}

//创建一个类实现增删改查

package com.xt.student.system;

public class StuStata {

/**
* 存放学生信息的数组
*/

private static List<Student> stuData = new LinkedList<Student>();

/**
* 学生数组信息存放标志位
*/

private static int dataIndex = 0;

/**
* 增加学生信息

*/

public void addStu(Student stu){

stuData.add(stu);
dataIndex++;
}

/**
* 根据学生编号删除学生信息
* 当查找到学生信息之后,将查找到的学生以后位置的学生信息向前移一位。

*/

public void delStu(String stuNo){
boolean boo = false;
for(int i = 0;i < dataIndex;i++){
if(stuData.get(i).getStuNo().equals(stuNo)){
stuData.remove(stuData.get(i));
boo = true;
break;
}
}
if(boo){
dataIndex--;
}
}

/**
* 修改学生信息
*/

public void update(Student stu){

for(int i = 0;i< dataIndex; i++){
if(stu.getStuNo().equals(stuData.get(i).getStuNo())){
stuData.set(i, stu);
}
}
}

/**
* 根据学生编号查询学生信息,当有此学生信息时,
* 返回学生信息,当学生信息不存在时,返回 Null
*

public Student getStuByStuNo(String stuNo){

for(int i = 0;i < dataIndex;i++){
if(stuNo.equals(stuData.get(i).getStuNo())){
return stuData.get(i);
}
}
return null;
}

public int getDataIndex(){

return dataIndex;
}

/**
* 获取所有的学生信息

*/

public Student getAllStuInfo(int i){

return stuData.get(i);

}

}

//根据用户输入的信息修改学生信息

package com.xt.student.system;

import java.util.List;
import java.util.Scanner;

public class stuSeverce {

StuStata sd = new StuStata();

public void addStuInfo(Scanner scanner){
Student stu = new Student();
System.out.println("请输入学生编号:");
String stuNo = scanner.next();
if(sd.getStuByStuNo(stuNo) != null){
System.out.println("此学生编号已存在,请选择操作:");
System.out.println("1 继续添加学生信息");
System.out.println("0 退出");
int optional = scanner.nextInt();
switch(optional){
case 0:
return;
case 1:
addStuInfo(scanner);
}
}
stu.setStuNo(stuNo);
System.out.println("请输入学生姓名:");
stu.setStuName(scanner.next());
System.out.println("请输入学生性别(男/女):");
stu.setGender(scanner.next());
System.out.println("请输入学生年龄:");
stu.setAge(scanner.nextInt());
System.out.println("请输入学生成绩:");
stu.setScore(scanner.nextInt());

sd.addStu(stu);
System.out.println("输入信息成功 \n");

}

public void printAllStuInfo(){
int dataIndex = sd.getDataIndex();
if(dataIndex == 0){
System.out.println("当前无学生信息! \n\n");
}
for(int i = 0; i < dataIndex ;i++){
Student stu = sd.getAllStuInfo(i);
printTitle();
System.out.println(""+stu.toString());
}

}

public void delStuInfo(Scanner scanner){
System.out.println("请输入要删除的学生编号:");
String stuNo = scanner.next();
if(sd.getStuByStuNo(stuNo) == null){
System.out.println("此学生编号不存在,请选择操作:");
System.out.println("1 继续删除学生信息");
System.out.println("0 退出");
int optional = scanner.nextInt();
switch(optional){
case 0:
return;
case 1:
delStuInfo(scanner);
}
}
sd.delStu(stuNo);
System.out.println("删除信息成功!\n");
}

public void updateStuInfo(Scanner scanner){
System.out.println("请输入要修改的学生编号:");
Student stu = new Student();
String stuNo = scanner.next();
if(sd.getStuByStuNo(stuNo) == null){
System.out.println("此学生编号不存在,请选择操作:");
System.out.println("1 继续修改学生信息");
System.out.println("0 退出");
int optional = scanner.nextInt();
switch(optional){
case 0:
return;
case 1:
updateStuInfo(scanner);
}
}
stu.setStuNo(stuNo);
System.out.println("请输入学生姓名:");
stu.setStuName(scanner.next());
System.out.println("请输入学生性别(男/女):");
stu.setGender(scanner.next());
System.out.println("请输入学生年龄:");
stu.setAge(scanner.nextInt());
System.out.println("请输入学生成绩:");
stu.setScore(scanner.nextInt());

sd.update(stu);
System.out.println("输入信息成功! \n");
}

public void checkStuInfo(Scanner scanner){
System.out.println("请输入所要查询的学生的编号");
String stuNo = scanner.next();
if(sd.getStuByStuNo(stuNo) == null){
System.out.println("此学生编号不存在,请选择操作:");
System.out.println("1 继续查询学生信息");
System.out.println("0 退出");
int optional = scanner.nextInt();
switch(optional){
case 0:
return;
case 1:
updateStuInfo(scanner);
}
}
printTitle();
System.out.println("" + sd.getStuByStuNo(stuNo).toString());
}

public void printTitle(){
System.out.print("| 学生编号 | 学生姓名 | 性别 | 年龄 | 成绩 | \n\n");
}

}

//菜单

package com.xt.student.system;

public class Menu {

public void showmenu(){
System.out.println("1:添加学生信息");
System.out.println("2:修改学生信息");
System.out.println("3:删除学生信息");
System.out.println("4:查询学生信息");
System.out.println("5:查询所有学生信息");
System.out.println("0:退出系统");
}

}

//主方法

package com.xt.student.system;

import java.util.Scanner;

public class Main {
public static void main(String[] args){
Scanner scanner = new Scanner(System.in);
System.out.println(" 欢迎来到学生信息管理系统 ");
Menu menu = new Menu();
stuSeverce stu = new stuSeverce();
while(true){
System.out.println("请按指示进行操作");
menu.showmenu();
int optional = scanner.nextInt();
switch(optional){
case 0:
System.out.println("退出系统");
System.exit(0);
break;
case 1:
stu.addStuInfo(scanner);
break;
case 2:
stu.updateStuInfo(scanner);
break;
case 3:
stu.delStuInfo(scanner);
break;
case 4:
stu.checkStuInfo(scanner);
break;
case 5:
stu.printAllStuInfo();
break;
}
}
}
}

时间: 2024-10-11 01:03:00

用基本数据结构修改后的学生信息管理系统(增删改查)的相关文章

MVC实例及用三层架构实现对学生信息的增删改查

一.MVC设计模式实例 M层 Login.java package org.entity; public class Login { private int id; private String uname; private String upwd; public Login() { } public Login( String uname, String upwd) { this.uname = uname; this.upwd = upwd; } public Login(int id, S

Redis 笔记与总结7 PHP + Redis 信息管理系统(用户信息的增删改查)

1. PHP 连接 Redis 访问 redis 官方网站的 client 栏目:http://www.redis.io/clients#php,可以获取 redis 的 php 扩展. 其中 phpredis 扩展比较稳定,功能也比较全,属于一个第三方扩展,但是已经被 PHP 官方授权,它的方法名和客户端下的方法名基本一致.github 地址:https://github.com/phpredis/phpredis,方法在这里也能查得到. ① 下载 phpredis 的源代码包,解压.配置.编

ASP.NET Core 打造一个简单的图书馆管理系统(七)外借/阅览图书信息的增删改查

前言: 本系列文章主要为我之前所学知识的一次微小的实践,以我学校图书馆管理系统为雏形所作. 本系列文章主要参考资料: 微软文档:https://docs.microsoft.com/zh-cn/aspnet/core/getting-started/?view=aspnetcore-2.1&tabs=windows <Pro ASP.NET MVC 5>.<锋利的 jQuery> 此系列皆使用 VS2017+C# 作为开发环境.如果有什么问题或者意见欢迎在留言区进行留言.

weiyi通讯录(二)获取联系人信息包括头像 增删改查功能,

看了下第一期的访问量,100都没有可能很多人不需要吧,之前跟过一个大神学做项目,他都不吧核心代码告诉我,感觉没有一点分享精神,所以我就自己做.没跟他一起做 这里把上次的代码分享一下 我这里分享的跟我博客里面可能不一样因为我已经做完第一个模块了,代码就没有分开了 第一期的代码地址:http://download.csdn.net/detail/u010982856/8232855 分享的是类似的代码 基本跟我的是一样.如果需要的联系人我把 或者加入我的交流群吧 -----------欢迎加入交流群

java测试类调用LDAP服务器客户端信息实行增删改查

如下是我自写的java测试类调用客户端配置好的用户信息: package com; import java.io.UnsupportedEncodingException; import java.util.Arrays; import java.util.Hashtable; import javax.naming.Context; import javax.naming.NamingEnumeration; import javax.naming.NamingException; impor

JAVA连接数据库后,对数据库进行增删改查

使用的方法:Statement 增删改: 方法:execute(String SQL) String url="jdbc:Access:///E://A//shop.mdb"; Connection con=null; //数据库连接对象 Statement st = null;//数据库操作对象 //SQL语句 //String sql="insert into goods values('7','鬼王','男','鬼王宗','伏龙鼎')"; String sql

6.实现struts2+hibernate实现学生列表的增删改查

1.dao 2.daoimpl 3.action 4.struts.xml(实现页面跳转)

使用python实现一个简单的学生信息管理系统

最近公司搬办公室,杂七杂八的事情比较多,又碰上业务要上线了...很多事情堆到一起来做,导致最近没什么时间学习,写博客.前两天胜利日放假,把以前用java写的学生信息管理系统用python重新写了一遍,以便于帮助python的学习. 好了,废话不多说,首先进行需求分析,下面是我根据需求画的系统结构图: 纯手工制图.....画的不好敬请谅解.从上图来看,整个系统分为main,add,delete,change,select,sort,io,print共八个模块,实现了对学生信息的增删改查排的功能,将

python练习——moudule02——员工信息增删改查

#作业名称:员工信息的增删改查 #作业需求: 1.可进行模糊查询,语法至少支持下面3种: select name,age from staff_table where age > 22 select * from staff_table where dept = "IT" select * from staff_table where enroll_date like "2013" 查到的信息,打印后,最后面还要显示查到的条数 2.可创建新员工纪录,以phon