java学习3创建学生属性:学号、姓名、电话 完全实现对象集合的增删改查。(控制台来做)
首先创建一个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创建学生属性:学号、姓名、电话 完全实现对象集合的增删改查。(控制台来做)的更多相关文章
- 学生信息管理系统--基于jsp技术和MySQL的简单增删改查
web实现增删改查的方式有很多啊,对于初学者来说当然是要先了解各部分的传值的方式.本篇博客从jsp技术的最基础方面进行说明. 一.什么是jsp技术 首先,我们要了解什么是jsp技术. jsp技术是基于 ...
- [刘阳Java]_程序员Java编程进阶的5个注意点,别编程两三年还是增删改查
此文章也是关注网上好几篇技术文章后,今天分享出来.因为,总有在程序学习路上的小伙伴会感到迷茫.而迷茫存在的情况如下 第一种:在大学学习中出现的迷茫,不知道Java到底要学什么.学习Java的标准是什么 ...
- Android学习笔记_9_SQLiteOpenHelper对象之数据库增删改查以及事务回滚操作
一.SQLite数据库: 在Android平台上,集成了一个嵌入式关系型数据库—SQLite,SQLite3支持 NULL.INTEGER.REAL(浮点数字).TEXT(字符串文本)和BLOB(二进 ...
- Java web 简单的增删改查程序(超详细)
就是简单的对数据进行增删改查.代码如下: 1.bean层:用来封装属性及其get set方法 toString方法,有参构造方法,无参构造方法等. public class Bean { privat ...
- Android学习---数据库的增删改查(sqlite CRUD)
上一篇文章介绍了sqlite数据库的创建,以及数据的访问,本文将主要介绍数据库的增删改查. 下面直接看代码: MyDBHelper.java(创建数据库,添加一列phone) package com. ...
- Android(java)学习笔记245:ContentProvider使用(银行数据库创建和增删改查的案例)
1. Android的四大组件: (1)Activity 用户交互的UI界面 (2)Service 后台运行的服务 (3)BroadcastReceiver 广播接收者 (4)ContentPro ...
- Android(java)学习笔记189:ContentProvider使用(银行数据库创建和增删改查的案例)
1. Android的四大组件: (1)Activity 用户交互的UI界面 (2)Service 后台运行的服务 (3)BroadcastReceiver 广播接收者 (4)ContentPro ...
- 招新系统(jsp+servlet,实现简略前端网页注册登录+后台增删改查,分学生和管理员,Java语言,mysql数据库连接,tomcat服务器)
生活不只是眼前的苟且,还有诗和远方. 架构说明: 要求是采用MVC模式,所以分了下面的几个包,但是由于是第一次写,可能分的也不是很清楚: 这个是后台部分的架构: 这个是前端的的展示: (那个StuLo ...
- 【良心保姆级教程】java手把手教你用swing写一个学生的增删改查模块
很多刚入门的同学,不清楚如何用java.swing去开发出一个系统? 不清楚如何使用java代码去操作数据库进行增删改查一些列操作,不清楚java代码和数据库(mysql.sqlserver)之间怎么 ...
随机推荐
- rosrun和roslaunch
rosrun allows you to run an executable(可执行) in an arbitrary(任意) package without having to cd (or ros ...
- sqlite 数据库错误 The database disk image is malformed database disk image
收银机上的sqlite数据库经常出现这种错误,错误的原因有可能是突然断电或是一些不规范操作导致的. 网上一般的做法有两种: 方法一: 1.在https://www.sqlite.org/downloa ...
- rbac 权限分配, 基于formset实现,批量编辑
已经完成了 批量添加的功能. 还想要一个批量修改的功能了.随之而来的第一个问题就是, 我们的formset 并不是一条记录.而是 多条记录,甚至整个表的记录.那么显而易见的问题就是,当前端页面把数 ...
- WebApi的过滤器
代码: using System; using System.Collections.Generic; using System.IO; using System.Linq; using System ...
- An enumerable sequence of parameters (arrays, lists, etc) is not allo
环境:dapper asp.net core 出错代码如下: public Task<IEnumerable<dynamic>> GetList(string query, p ...
- andorid UI事件
- bloomfilter 以及count min sketch
bloomfilter http://blog.csdn.net/v_july_v/article/details/6685894 count min sketch http://www.cnblog ...
- Linux内核哈希表分析与应用
目录(?)[+] Linux内核哈希表分析与应用 Author:tiger-johnTime:2012-12-20mail:jibo.tiger@gmail.comBlog:http:// ...
- Java.FamousBlogs
本文总结在工作/学习中发现的Java相关的blogs. 1. java code geeks (jcg) http://www.javacodegeeks.com/join-us/jcg/ 2. ht ...
- muduo 的windows下的编译
四处寻觅开源代码学习,适合的代码非常稀少,不适合的原因却千奇百怪. 不是使用语言特性过于老旧(c++03) 就是使用的冷僻语法(template<T> enable_share_from_ ...