实训第三天 学生信息管理系统

实训目的:综合运用J2SE有关知识开发【学生信息管理系统】。主要涉及程序控制结构、面向对象编程、图形用户界面、Java数据库应用、MySQL数据库这几个方面的内容。通过本项目的开发,让学生了解系统开发的一般流程,初步了解MVC模式与单元测试,巩固所学的Java理论知识,提高Java数据库应用编程的基本技能。
知识点:
(1)Java基本语法
(2)Java流程控制(顺序、选择、循环)
(3)Java数据库编程(JDBC)
(4)Java面向对象编程(封装、继承、多态、接口)
(5)Java核心API(List、Vector……)
(6)MySQL数据库操作
(7)MVC模式分层架构(M:模型层、V:视图层、C:控制层)

、测试Dao里面的,接着前一天的测试:(前一天已经测试了1,2,3,4)
测试StudentDaolmpl里面共有13个
1. int insert(Student student);
2. int deleteById(String id);
3. int deleteByClass(String clazz);
4.int deleteByDepartment(String department);
5. int update(Student student);
6.Student findById(String id);
7. List findByName(String name);
8. List findByClass(String clazz);
9.List findByDepartment(String department);
10.List findAll();
11. Vector findRowsBySex();
12. Vector findRowsByClass();
13. Vector findRowsByDepartment();

5.用update更新数据

6.编写测试插入的方法 findById():
@Test
public void testFindById(){
StudentDao dao=new StudentDaoImpl();
String id=“11040201”;
Student student=dao.findById(id);
System.out.println(student);
}
运行该测试方法,结果如下:

7.编写测试插入的方法 findByName():
@Test
public void testFindByName() {
StudentDao dao = new StudentDaoImpl();
String name = “李”;
List students = dao.findByName(name);
if (students.size() > 0) {
for (Student student : students) {
System.out.println(student);
}
} else {
System.out.println(“温馨提示:查无此人”);
}
}
运行该测试方法,结果如下:
在这里插入图片描述可以打开数据库中的t_student检验一下是否正确
8.编写测试插入的方法 findByClass():
@Test
public void testFindByClass(){
StudentDao dao=new StudentDaoImpl();
String clazz=“10英教1班”;
List students=dao.findByClass(clazz);
for(Student student:students){
System.out.println(student);
}
}
运行该测试方法,结果如下:
在这里插入图片描述可以打开数据库中的t_student检验一下是否正确
9.编写测试插入的方法 findByDepartment():
@Test
public void testFindByDepartment(){
StudentDao dao=new StudentDaoImpl();
String department=“外语系”;
List students=dao.findByDepartment(department);
for (Student student:students){
System.out.println(student);
}
}
运行该测试方法,结果如下:
实训第三天 学生信息管理系统_第1张图片可以打开数据库中的t_student检验一下是否正确
10.编写测试插入的方法 findAll():
@Test
public void testFindAll(){
StudentDao dao=new StudentDaoImpl();
String name="*";
List students=dao.findAll();
for (Student student:students){
System.out.println(student);
}
}
运行该测试方法,结果如下:
实训第三天 学生信息管理系统_第2张图片可以打开数据库中的t_student检验一下是否正确
11.编写测试插入的方法 findRowsBySex():
@Test
public void testFindRowsBySex(){
StudentDao dao=new StudentDaoImpl();
Vector rows=dao.findRowsBySex();
Iterator iterator=rows.iterator();
while (iterator.hasNext()){
System.out.println(iterator.next());
}
}
运行该测试方法,结果如下:
实训第三天 学生信息管理系统_第3张图片可以打开数据库中的t_student检验一下是否正确
12.编写测试插入的方法 findRowsByClass():
@Test
public void testFindRowsByClass(){
StudentDao dao=new StudentDaoImpl();
String clazz=“10英教1班”;
Vector rows=dao.findRowsByClass();
List students=dao.findRowsByClass();
Iterator iterator=rows.iterator();
while (iterator.hasNext()){
System.out.println(iterator.next());
}
}
运行该测试方法,结果如下:
实训第三天 学生信息管理系统_第4张图片
可以打开数据库中的t_student检验一下是否正确
13.编写测试插入的方法 findRowsByDepartment():
@Test
public void testFindRowsByDepartment(){
StudentDao dao=new StudentDaoImpl();
String department=“外语系”;
Vector rows=dao.findRowsByDepartment();
Iterator iterator=rows.iterator();
while (iterator.hasNext()){
System.out.println(iterator.next());
}
}
运行该测试方法,结果如下:
实训第三天 学生信息管理系统_第5张图片
可以打开数据库中的t_student检验一下是否正确
、测试UserDaolmpl:(一共有6个)
1.int insert(User user);
**2.**int deleteById(int id);
3. int update(User user);
4.User findById(int id);
5. List findAll();
**6.**User login(String username, String password);
1.编写测试插入的方法 insert():
@Test
public void testInsert(){
User user=new User();
user.setId(7);
user.setUsername(“张正敏”);
user.setPassword(“666666”);
user.setTelephone(“18780636650”);
user.setRegisterTime(new Timestamp(new Date().getTime()));

    UserDao dao=new UserDaolmpl();
     int count=dao.insert(user);
     if(count>0){
         System.out.println("恭喜,添加用户成功");
     }else {
         System.out.println("遗憾,添加用户失败");
     }
}

运行该测试方法,结果如下:
实训第三天 学生信息管理系统_第6张图片
可以打开数据库中的t_user检验一下是否正确
在这里插入图片描述 2.编写测试插入的方法 deleteById():
@Test
public void testDeleteById(){
UserDao dao=new UserDaolmpl();
int id=3;
int count=dao.deleteById(id);
if (count>0){
System.out.println(“恭喜,学生删除成功”);
}else {
System.out.println(“遗憾,学生删除失败”);
}
}
运行该测试方法,结果如下:
实训第三天 学生信息管理系统_第7张图片可以打开数据库中的t_user检验一下是否正确
3.编写测试插入的方法 update():
@Test
public void testUpdate(){
UserDao dao=new UserDaolmpl();
User user = dao.findById(1);
user.setUsername(“张3敏”);
user.setTelephone(“18780636650”);
int count = dao.update(user);
if (count > 0) {
System.out.println(“恭喜,状态更新记录成功”);
user = dao.findById(1);
System.out.println(user);
} else {
System.out.println(“遗憾,状态更新记录失败”);
}
}
运行该测试方法,结果如下:

可以打开数据库中的t_user检验一下是否正确
4.编写测试插入的方法findById():
@Test
public void testFindById(){
UserDao dao=new UserDaolmpl();
int id=3;
User user=dao.findById(id);
System.out.println(user);
}
运行该测试方法,结果如下:
在这里插入图片描述可以打开数据库中的t_user检验一下是否正确
5.编写测试插入的方法findAll():
@Test
public void testFindAll(){
UserDao dao=new UserDaolmpl();
String username="*";
List users=dao.findAll();
for (User user:users){
System.out.println(user);
}
}
运行该测试方法,结果如下:
实训第三天 学生信息管理系统_第8张图片可以打开数据库中的t_user检验一下是否正确
6.编写测试插入的方法login():
@Test
public void testLogin(){
UserDao dao=new UserDaolmpl();
String username,password;
username=“admin”;
password=“12345”;
User user=dao.login(username,password);
if(user!=null){
System.out.println(“恭喜,用户名与密码正确”);
}else {
System.out.println(“遗憾,用户名与密码错误”);
}
}
运行该测试方法,结果如下:
实训第三天 学生信息管理系统_第9张图片可以打开数据库中的t_user检验一下是否正确
**三、**服务接口
实训第三天 学生信息管理系统_第10张图片
1)学校服务接口CollegeService
package net.zzm.student.service;

import net.zzm.student.bean.College;

public interface CollegeService {
College findCollegeById(int id);
int updateCollege(College college);
}
2)状态服务接口StatusService
package net.zzm.student.service;

import net.zzm.student.bean.Status;

public interface StatusService {
Status findStatusById(int id);
int updateStatus(Status status);
}
3)学生服务接口StudentService
package net.zzm.student.service;

import net.zzm.student.bean.Student;

import java.awt.*;
import java.util.List;
import java.util.Vector;

public interface StudentService {
int addStudent(Student student);
int deleteStudentById(String id);
int deleteStudentByClass(String clazz);
int deleteStudentByDepartment(String department);
int updateStudent(Student student);
Student findStudentById(String id);
List findStudentByName(String name);
List findStudentByClass(String clazz);
List findStudentByDepartment(String department);
List findAllStudent();
Vector findRowsBySex();
Vector findRowsByClass();
Vector findRowsByDepartment();
}
4)用户服务接口UserService
import net.zzm.student.bean.User;

import java.util.List;

public interface UserService {
int addUser(User user);
int deleteUserById(int id);
int updateUser(User user);
User findUserId(int id);
List findAllUsers();
User login(String username,String password);
}
四、服务接口实现类
实训第三天 学生信息管理系统_第11张图片1)学校服务接口实现类CollegeServiceImpl
package net.zzm.student.service.impl;

import net.zzm.student.bean.College;
import net.zzm.student.dao.CollegeDao;
import net.zzm.student.dao.impl.CollegeDaolmpl;
import net.zzm.student.service.CollegeService;

public class CollegeServicelmpl implements CollegeService {
private CollegeDao collegeDao=new CollegeDaolmpl();
@Override
public College findCollegeById(int id) {
return collegeDao.findById(id);
}

@Override
public int updateCollege(College college) {
    return collegeDao.update(college);
}

}
在net.zzm.student.test包里创建测试类TestCollegeServiceImpl:
在这里插入图片描述在这里面要测试两个
College findCollegeById(int id);
int updateCollege(College college);
@1。编写测试插入的方法FindCollegeByIdl():
@Test
public void testFindCollegeById(){
CollegeService service=new CollegeServicelmpl();
College college=service.findCollegeById(1);
System.out.println(college);
}
运行该测试方法,结果如下:
实训第三天 学生信息管理系统_第12张图片@2.编写测试插入的方法UpdateCollegel()
@Test
public void testUpdateCollege(){
CollegeService service=new CollegeServicelmpl();
College college=service.findCollegeById(1);
college.setPresident(“贺成”);
college.setTelephone(“3152639”);
int count=service.updateCollege(college);
if (count>0){
System.out.println(“恭喜,学校记录更新成功”);
college=service.findCollegeById(1);
System.out.println(college);
}else {
System.out.println(“遗憾,学校记录更新失败”);
}
}
}
运行该测试方法,结果如下:
在这里插入图片描述
2)状态服务接口实现类StatusServiceImpl
package net.zzm.student.service.impl;

import net.zzm.student.bean.Status;
import net.zzm.student.dao.StatusDao;
import net.zzm.student.dao.impl.StatusDaolmpl;
import net.zzm.student.service.StatusService;

public class StatusServiceImpl implements StatusService {
private StatusDao statusDao=new StatusDaolmpl();
@Override
public Status findStatusById(int id){
return statusDao.findById(id);
}

@Override
public int updateStatus(Status status) {
    return statusDao.update(status);
}

}
在net.zzm.student.test包里创建测试类TestStatusServiceImpl:
在这里插入图片描述
这个里面要测试两个
Status findStatusById(int id);
int updateStatus(Status status);
@1.编写测试插入的方法findStatusById():
@Override
public Status findStatusById(int id){
return statusDao.findById(id);
}
编写测试方法testFindStatusById()
@Test
public void testFindStatusById(){
StatusService service=new StatusServiceImpl();
Status status=service.findStatusById(1);
System.out.println(status);
}
运行该测试方法,结果如下:
在这里插入图片描述@2.编写测试插入的方法updateStatus()
@Override
public int updateStatus(Status status) {
return statusDao.update(status);
}
编写测试方法updateStatus()
在这里插入图片描述3)学生服务接口实现类StudentServiceImpl
package net.zzm.student.service.impl;

import net.zzm.student.bean.Student;
import net.zzm.student.dao.StudentDao;
import net.zzm.student.dao.impl.StudentDaoImpl;
import net.zzm.student.service.StudentService;

import java.util.List;
import java.util.Vector;

public class StudentServicelmpl implements StudentService {
private StudentDao studentDao=new StudentDaoImpl();

@Override
public int addStudent(Student student) {
    return studentDao.insert(student);
}

@Override
public int deleteStudentById(String id) {
    return studentDao.deleteById(id);
}

@Override
public int deleteStudentByClass(String clazz) {
    return studentDao.deleteByClass(clazz);
}

@Override
public int deleteStudentByDepartment(String department) {
    return studentDao.deleteByDepartment(department);
}

@Override
public int updateStudent(Student student) {
    return studentDao.update(student);
}

@Override
public Student findStudentById(String id) {
    return studentDao.findById(id);
}

@Override
public List findStudentByName(String name) {
    return studentDao.findByName(name);
}

@Override
public List findStudentByClass(String clazz) {
    return studentDao.findByClass(clazz);
}

@Override
public List findStudentByDepartment(String department) {
    return studentDao.findByDepartment(department);
}

@Override
public List findAllStudent() {
    return studentDao.findAll();
}

@Override
public Vector findRowsBySex() {
    return studentDao.findRowsBySex();
}

@Override
public Vector findRowsByClass() {
    return studentDao.findRowsByClass();
}

@Override
public Vector findRowsByDepartment() {
    return studentDao.findRowsByDepartment();
}

}
在net.zzm.student.test包里创建测试类TestStudentServiceImpl:
在这里插入图片描述编写测试方法testFindStudentsByName():
一共有13种方法要测试
1.int addStudent(Student student);
2. int deleteStudentById(String id);
3. int deleteStudentByClass(String clazz);
4. int deleteStudentByDepartment(String department);
5. int updateStudent(Student student);
6. Student findStudentById(String id);
7. List findStudentByName(String name);
8. List findStudentByClass(String clazz);
9. List findStudentByDepartment(String department);
10. List findAllStudent();
11. Vector findRowsBySex();
12. Vector findRowsByClass();
13. Vector findRowsByDepartment();
@1…编写测试插入的方法addStudent():
@Test
public void testAddStudent(){
Student student=new Student();
student.setId(“18242026”);
student.setName(“张敏”);
student.setSex(“女”);
student.setAge(19);
student.setDepartment(“信息工程学院”);
student.setClazz(“18大数据1班”);
student.setTelephone(“18780636650”);

    StudentService service=new StudentServicelmpl();
    int count=service.addStudent(student);
    if (count>0){
        System.out.println( "恭喜,添加学生成功");
    }else {
        System.out.println("遗憾,添加学生失败");
    }
}

运行该测试方法,结果如下: 实训第三天 学生信息管理系统_第13张图片 @2.编写测试插入的方法deleteStudentById():
@Test
public void testDeleteStudentById(){
StudentService service=new StudentServicelmpl();
String id=“10080301”;
int count=service.deleteStudentById(id);
if(count>0){
System.out.println(“恭喜,学生删除成功”);
}else {
System.out.println(“遗憾,学生删除失败”);
}
}

运行该测试方法,结果如下:
实训第三天 学生信息管理系统_第14张图片
可打开数据库查看是否正确
@3…编写测试插入的方法deleteStudentByClass():
@Test
public void testDeleteStudentByClass(){
StudentService service=new StudentServicelmpl();
String clazz = “18大数据1班”;
int count=service.deleteStudentByClass(clazz);
if (count >0){
System.out.println(“恭喜,班级删除成功”);
}else {
System.out.println(“遗憾,班级删除失败”);
}
}

运行该测试方法,结果如下:
实训第三天 学生信息管理系统_第15张图片如果没有改班级则删除不成功
可以打开t_student查看是否正确
@4…编写测试插入的方法deleteStudentByDepartment():
@Test
public void testDeleteStudentByDepartment(){
StudentService service=new StudentServicelmpl();
String department=“信息工程学院”;
int count=service.deleteStudentByDepartment(department);
if (count>0){
System.out.println(“恭喜,系部删除成功”);
}else {
System.out.println(“遗憾,系部删除失败”);
}
}
运行该测试方法,结果如下:
如果没有改班级则删除不成功
可以打开t_student查看是否正确实训第三天 学生信息管理系统_第16张图片如果没有改系部则不成功
可以打开t_student查看是否正确
@5…编写测试插入的方法updateStuden():
实训第三天 学生信息管理系统_第17张图片 可以打开t_student查看是否正确
@6.编写测试插入的方法 findStudentById():
@Test
public void testFindStudentById(){
StudentService service=new StudentServicelmpl();
String id=“11040201”;
Student student=service.findStudentById(id);
System.out.println(student);
}
运行该测试方法,结果如下:

@7.编写测试插入的方法 findStudentByName():
@Test
public void testFindStudentByName(){
StudentService service=new StudentServicelmpl();
String name = “李”;
List students = service.findStudentByName(name);
if (students.size() > 0) {
for (Student student : students) {
System.out.println(student);
}
} else {
System.out.println(“温馨提示:查无此人”);
}
}
运行该测试方法,结果如下:
在这里插入图片描述
可打开数据库查看

@8.编写测试插入的方法 findStudentByClass():
@Test
public void testFindStudentByClass(){
StudentService service=new StudentServicelmpl();
String clazz=“10英教1班”;
List students=service.findStudentByClass(clazz);
for(Student student:students){
System.out.println(student);
}
}
运行该测试方法,结果如下:
在这里插入图片描述
可打开数据库查看
@9.编写测试插入的方法findStudentByDepartment():
@Test
public void testFindStudentByDepartment(){
StudentService service=new StudentServicelmpl();
String department=“外语系”;
List students=service.findStudentByDepartment(department);
for (Student student:students){
System.out.println(student);
}
}
运行该测试方法,结果如下:
实训第三天 学生信息管理系统_第18张图片
可打开数据库查看
@10.编写测试插入的方法 findAllStudent():
@Test
public void testFindAllStudent(){
StudentService service=new StudentServicelmpl();
String name="*";
List students=service.findAllStudent();
for (Student student:students){
System.out.println(student);
}
}
运行该测试方法,结果如下:
实训第三天 学生信息管理系统_第19张图片
可打开数据库查看
@11.编写测试插入的方法findRowsBySex():
@Test
public void testFindRowsBySex(){
StudentService service=new StudentServicelmpl();
Vector rows=service.findRowsBySex();
Iterator iterator=rows.iterator();
while (iterator.hasNext()){
System.out.println(iterator.next());
}
}
运行该测试方法,结果如下:
实训第三天 学生信息管理系统_第20张图片
可打开数据库查看
@12.编写测试插入的方法 findRowsByClass():
@Test
public void testFindRowsByClass(){
StudentService service=new StudentServicelmpl();
String clazz=“10英教1班”;
Vector rows=service.findRowsByClass();
List students=service.findStudentByClass(clazz);
Iterator iterator=rows.iterator();
while (iterator.hasNext()){
System.out.println(iterator.next());
}
}
运行该测试方法,结果如下:
实训第三天 学生信息管理系统_第21张图片
可打开数据库查看
@13.编写测试插入的方法findRowsByDepartment():
@Test
public void testFindRowsByDepartment(){
StudentService service=new StudentServicelmpl();
String department=“外语系”;
Vector rows=service.findRowsByDepartment();
Iterator iterator=rows.iterator();
while (iterator.hasNext()){
System.out.println(iterator.next());
}
}
运行该测试方法,结果如下:
实训第三天 学生信息管理系统_第22张图片可打开数据库查看
4)用户服务接口实现类UserServiceImpl
package net.zzm.student.service.impl;

import net.zzm.student.bean.User;
import net.zzm.student.dao.UserDao;
import net.zzm.student.dao.impl.UserDaolmpl;
import net.zzm.student.service.UserService;

import java.util.List;

public class UserServiceImpl implements UserService {
private UserDao userDao=new UserDaolmpl();

@Override
public int addUser(User user) {
    return userDao.insert(user);
}

@Override
public int deleteUserById(int id) {
    return userDao.deleteById(id);
}

@Override
public int updateUser(User user) {
    return userDao.update(user);
}

@Override
public User findUserId(int id) {
    return userDao.findById(id);
}

@Override
public List findAllUsers() {
    return userDao.findAll();
}


@Override
public User login(String username, String password) {
    return userDao.login(username, password);
}

}
在net.zzm.student.test包里创建测试类TestUserServiceImpl:
在这里插入图片描述
这李一共有6种方法:

**1.**int addUser(User user);
2. int deleteUserById(int id);
**3.**int updateUser(User user);
**4.**User findUserId(int id);
5.List findAllUsers();
6.User login(String username,String password);
1.@编写测试方法addUser()方法:
@Test
public void tesAddUsers() {
User user = new User();
user.setUsername(“张琴”);
user.setPassword(“777777”);
user.setRegisterTime(new Timestamp(new Date().getTime()));
user.setTelephone(“18780636650”);

        UserDao dao = new UserDaolmpl();
        int count = dao.insert(user);
        if (count > 0) {
            System.out.println("恭喜,添加学生成功");
        } else {
            System.out.println("遗憾,添加学生失败");
        }

运行该测试方法,结果如下:
实训第三天 学生信息管理系统_第23张图片
@2.编写测试方法deleteUserById()方法:
@Test
public void testDeleteUserById() {
UserService service = new UserServiceImpl();
int id = 1;
int count = service.deleteUserById(id);
if (count > 0) {
System.out.println(“恭喜,学生删除成功”);
} else {
System.out.println(“遗憾,学生删除失败”);
}
}
运行该测试方法,结果如下:
实训第三天 学生信息管理系统_第24张图片

@3. 编写测试方法updateUser()方法:

运行该测试方法,结果如下:
@4.编写测试方法findUserId()方法:
@Test
public void testFindUserId() {
UserService service = new UserServiceImpl();
int id = 1;
User user = service.findUserId(id);
System.out.println(user);
}
运行该测试方法,结果如下:

@5.编写测试方法 findAllUsers()方法:

@Test
public void testFindAllUsers() {
UserService service = new UserServiceImpl();
String username = “*”;
List users = service.findAllUsers();
for (User user : users) {
System.out.println(user);
}
}
运行该测试方法,结果如下:
实训第三天 学生信息管理系统_第25张图片
@6.编写测试方法 login()方法:
@Test
public void testLogin() {
UserService service = new UserServiceImpl();
String username, password;

    username = "admin";
    password = "12345";

    User user = service.login(username, password);
    if (user != null) {
        System.out.println("恭喜,用户名与密码正确");
    } else {
        System.out.println("遗憾,用户名与密码错误");
    }
}
运行该测试方法,结果如下:

实训第三天 学生信息管理系统_第26张图片

你可能感兴趣的:(学习,实训,学习)