首先创建一个student类其中包括get,set与构造函数

/**
*
*/
package work2;

/**
* @author Administrator
*
*/
public final class Student {
private String id;
private int tell;
private String name;
/**
* 初始化数据
*/
public Student(String id,int tell,String name) {//构造函数赋初值
// TODO 自动生成的构造函数存根
this.id=id;
this.tell=tell;
this.name=name;
}

/**
*
* @param 传入数据set与get方法,数据的安全性,给了方法自己传入数据
*/

public void setId(String id){
this.id=id;
}
public void setTell(int tell){
this.tell=tell;
}
public void setName(String name){
this.name=name;
}
public String getId(){
return id;
}
public int geiTell(){
return tell;
}
public String geiName(){
return name;
}
}

在创建一个一个MyClass类包括增删改查方法

package work2;

import java.util.ArrayList;
import java.util.List;

public class MyClass {
// 建立一个List容器装数据
private List<Student> stuList;

public MyClass(){
stuList=new ArrayList<Student>();//建立一个stu对象
}

public boolean isHere(Student stu){//封装判断一个数的方法
boolean is=false;
for(Student s:stuList){//遍历for each
if(stu.getId().equals(s.getId()))//容器里传入的对象数据=遍历的对象数据,则存在,否则不存在
is=true;
}
return is;//返回判断
}

public boolean add(Student stu){
//首先判断是否存在
boolean is=this.isHere(stu);
if(!is){
stuList.add(stu);
}
return !is;
}

public boolean upDate(Student stu){
//首先判断是否存在
boolean is=this.isHere(stu);
for(Student s:stuList){
if(stu.getId().equals(s.getId())){
stuList.remove(s);
stuList.add(stu);
}
}
return is;
}

public boolean delete(String id){
boolean isSuc=false;
for(Student s:stuList){
if(id.equals(s.getId())){
stuList.remove(s);
isSuc=true;
}
}
return isSuc;
}

public List<Student> query(){
return this.stuList;

}
}

最后创建一个MainFrame类运用model view controller

通过调用MyClass中的方法实现

package work2;

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

import javax.swing.plaf.synth.SynthStyle;

public class MainFrame {
public MyClass mc;//对象
private Scanner sc=new Scanner(System.in);
public MainFrame() {
// TODO 自动生成的构造函数存根
mc=new MyClass();
}
public Student getInfo(){//带参数的构造函数
System.out.println("请输入学号");
String id=sc.next();
System.out.println("请输入电话");
int tell=sc.nextInt();
System.out.println("请输入姓名");
String name=sc.next();
Student stu=new Student(id, tell, name);//数据封装成对象,
return stu;

}
public void add(){
Student stu=this.getInfo();//从控制台接收数据
boolean is=mc.add(stu);
if(is){
System.err.println("添加成功");

}
else
System.out.println("添加失败");
}

public void update(){
Student stu=this.getInfo();
boolean is=mc.upDate(stu);
if(is){
System.out.println("修改·成功");
}else
System.out.println("修改失败");
}
public void delete(){
System.out.println("请输入要删除学生的学号");
String id=sc.next();
boolean is=mc.delete(id);
if(is){
System.out.println("删除成功");
}else
System.out.println("删除失败,学生不存在");

}

public void quere(){
List<Student> stulist=mc.query();
for(Student s:stulist){
System.out.println("ID:"+s.getId()+"tell:"+s.geiTell()+"name:"+s.geiName());

}
}

public void start(){
boolean is=true;
while(is){
System.out.println("输入你要操作的选项:");
System.out.println("1,增加");
System.out.println("2.删除");
System.out.println("3,修改");
System.out.println("4,查找");
System.out.println("5,退出");
int option=sc.nextInt();
switch (option) {
case 1:
System.out.println("开始添加");
add();
break;

case 2:
System.out.println("开始修改");
update();
break;
case 3:
System.out.println("开始查询");
quere();
break;
case 4:
System.out.println("开始删除");
delete();
break;
case 5:
is=false;
System.out.println("欢迎使用,下次再见!!");
}
}

}
public static void main(String[] args) {
MainFrame mf=new MainFrame();
mf.start();
}

}

java学习3创建学生属性:学号、姓名、电话 完全实现对象集合的增删改查。(控制台来做)的更多相关文章

  1. 学生信息管理系统--基于jsp技术和MySQL的简单增删改查

    web实现增删改查的方式有很多啊,对于初学者来说当然是要先了解各部分的传值的方式.本篇博客从jsp技术的最基础方面进行说明. 一.什么是jsp技术 首先,我们要了解什么是jsp技术. jsp技术是基于 ...

  2. [刘阳Java]_程序员Java编程进阶的5个注意点,别编程两三年还是增删改查

    此文章也是关注网上好几篇技术文章后,今天分享出来.因为,总有在程序学习路上的小伙伴会感到迷茫.而迷茫存在的情况如下 第一种:在大学学习中出现的迷茫,不知道Java到底要学什么.学习Java的标准是什么 ...

  3. Android学习笔记_9_SQLiteOpenHelper对象之数据库增删改查以及事务回滚操作

    一.SQLite数据库: 在Android平台上,集成了一个嵌入式关系型数据库—SQLite,SQLite3支持 NULL.INTEGER.REAL(浮点数字).TEXT(字符串文本)和BLOB(二进 ...

  4. Java web 简单的增删改查程序(超详细)

    就是简单的对数据进行增删改查.代码如下: 1.bean层:用来封装属性及其get set方法 toString方法,有参构造方法,无参构造方法等. public class Bean { privat ...

  5. Android学习---数据库的增删改查(sqlite CRUD)

    上一篇文章介绍了sqlite数据库的创建,以及数据的访问,本文将主要介绍数据库的增删改查. 下面直接看代码: MyDBHelper.java(创建数据库,添加一列phone) package com. ...

  6. Android(java)学习笔记245:ContentProvider使用(银行数据库创建和增删改查的案例)

    1. Android的四大组件: (1)Activity  用户交互的UI界面 (2)Service  后台运行的服务 (3)BroadcastReceiver 广播接收者 (4)ContentPro ...

  7. Android(java)学习笔记189:ContentProvider使用(银行数据库创建和增删改查的案例)

    1. Android的四大组件: (1)Activity  用户交互的UI界面 (2)Service  后台运行的服务 (3)BroadcastReceiver 广播接收者 (4)ContentPro ...

  8. 招新系统(jsp+servlet,实现简略前端网页注册登录+后台增删改查,分学生和管理员,Java语言,mysql数据库连接,tomcat服务器)

    生活不只是眼前的苟且,还有诗和远方. 架构说明: 要求是采用MVC模式,所以分了下面的几个包,但是由于是第一次写,可能分的也不是很清楚: 这个是后台部分的架构: 这个是前端的的展示: (那个StuLo ...

  9. 【良心保姆级教程】java手把手教你用swing写一个学生的增删改查模块

    很多刚入门的同学,不清楚如何用java.swing去开发出一个系统? 不清楚如何使用java代码去操作数据库进行增删改查一些列操作,不清楚java代码和数据库(mysql.sqlserver)之间怎么 ...

随机推荐

  1. rosrun和roslaunch

    rosrun allows you to run an executable(可执行) in an arbitrary(任意) package without having to cd (or ros ...

  2. sqlite 数据库错误 The database disk image is malformed database disk image

    收银机上的sqlite数据库经常出现这种错误,错误的原因有可能是突然断电或是一些不规范操作导致的. 网上一般的做法有两种: 方法一: 1.在https://www.sqlite.org/downloa ...

  3. rbac 权限分配, 基于formset实现,批量编辑

    已经完成了  批量添加的功能. 还想要一个批量修改的功能了.随之而来的第一个问题就是,  我们的formset 并不是一条记录.而是 多条记录,甚至整个表的记录.那么显而易见的问题就是,当前端页面把数 ...

  4. WebApi的过滤器

    代码: using System; using System.Collections.Generic; using System.IO; using System.Linq; using System ...

  5. An enumerable sequence of parameters (arrays, lists, etc) is not allo

    环境:dapper asp.net core 出错代码如下: public Task<IEnumerable<dynamic>> GetList(string query, p ...

  6. andorid UI事件

  7. bloomfilter 以及count min sketch

    bloomfilter http://blog.csdn.net/v_july_v/article/details/6685894 count min sketch http://www.cnblog ...

  8. Linux内核哈希表分析与应用

        目录(?)[+]   Linux内核哈希表分析与应用 Author:tiger-johnTime:2012-12-20mail:jibo.tiger@gmail.comBlog:http:// ...

  9. Java.FamousBlogs

    本文总结在工作/学习中发现的Java相关的blogs. 1. java code geeks (jcg) http://www.javacodegeeks.com/join-us/jcg/ 2. ht ...

  10. muduo 的windows下的编译

    四处寻觅开源代码学习,适合的代码非常稀少,不适合的原因却千奇百怪. 不是使用语言特性过于老旧(c++03) 就是使用的冷僻语法(template<T> enable_share_from_ ...