Bootstrap

Redis版学生管理系统(java)

【问题简述】:

要求用Redis完成以下功能,根据功能使用合适的数据结构:

(1)add(Stu), 增加学生时给个独一无二的id,username、phone手机号、java成绩、math成绩可以随意赋个合适值(不要从控制台输入),username有可能重名的情况,增加时无需特殊处理。phone必须保证唯一,如果不唯一,给出错误信息

(2) findByUsername(String),按照姓名查询,考虑查询到和查询不到,也要考虑重名情况,有多少个显示多少个。显示查询到学生信息。

(3)sortAvg(),用sorted set实现按平均成绩降序排序,并分页,分页大小为2,每页显示两个学生信息。

(4)sortAvgBySoringParam(int page),用SortingParams实现按平均成绩降序排序

【代码示例】:
package org.example;
public class Student {
    private String username;
    private String phone;
    private int javaScore;
    private int mathScore;
    private long id;
    private double averageScore;
    public String getUsername() {
        return username;
    }
    public void setUsername(String username) {
        this.username = username;
    }
    public String getPhone() {
        return phone;
    }
    public void setPhone(String phone) {
        this.phone = phone;
    }
    public int getJavaScore() {
        return javaScore;
    }
    public void setJavaScore(int javaScore) {
        this.javaScore = javaScore;
    }
    public int getMathScore() {
        return mathScore;
    }
    public void setMathScore(int mathScore) {
        this.mathScore = mathScore;
    }
    public long getId(){
        return id;
    }
    public void setId(long id) {
        this.id=id;
    }
    public void setAvgScore(double averageScore) {
        this.averageScore=averageScore;
    }
    public double getAvgScore(){
        return averageScore;
    }
    @Override
    public String toString() {
        return "Student{" +
                "id=" + id +
                ", username='" + username + '\'' +
                ", phone='" + phone + '\'' +
                ", javaScore=" + javaScore +
                ", mathScore=" + mathScore +
                ", averageScore=" + averageScore +
                '}';
    }
}
package org.example;

import redis.clients.jedis.Jedis;
import redis.clients.jedis.Tuple;
import java.util.*;
public class StudentManager {
    private static Jedis jedis;
    private static final String stuPrefix = "student:";
    private static final String phoneKey = "phone_set";
    public StudentManager() {
        jedis = new Jedis("localhost");
    }
    // (1)增加
    public void add(Student stu) {
        long studentId = jedis.incr("student_id_counter");
        String studentKey = stuPrefix + studentId;
        String phone = stu.getPhone();
        if (jedis.sismember(phoneKey, phone)) {
            //throw new IllegalArgumentException("PhoneNumber already exists.");
            System.out.println("电话号码已经存在,增加学生失败。");
            System.out.println();
        }
        else{
            System.out.println("添加成功!");
        }
        jedis.hset(studentKey, "username", stu.getUsername());
        jedis.hset(studentKey, "phone", phone);
        jedis.hset(studentKey, "java", Integer.toString(stu.getJavaScore()));
        jedis.hset(studentKey, "math", Integer.toString(stu.getMathScore()));
        jedis.sadd(phoneKey, phone);
    }
    //(2)
    public List<Student> findByUsername(String username) {
        List<Student> result = new ArrayList<>();

        Set<String> studentKeys = jedis.keys(stuPrefix + "*");

        for (String key : studentKeys) {
            String storedUsername = jedis.hget(key, "username");

            if (storedUsername.equals(username)) {
                Map<String, String> studentData = jedis.hgetAll(key);
                Student student = new Student();
                student.setId(Long.parseLong(key.split(":")[1]));
                student.setUsername(studentData.get("username"));
                student.setPhone(studentData.get("phone"));
                student.setJavaScore(Integer.parseInt(studentData.get("java")));
                student.setMathScore(Integer.parseInt(studentData.get("math")));
                result.add(student);
            }
        }
        return result;
    }
    //(3)
    public List<Student> sortAvg() {
        List<Student> result = new ArrayList<>();

        Set<String> studentIds = jedis.zrevrangeByScore("students_average_score", "+inf", "-inf");

        for (String studentId : studentIds) {
            String studentKey = stuPrefix + studentId;
            Map<String, String> studentData = jedis.hgetAll(studentKey);

            Student student = new Student();
            student.setId(Long.parseLong(studentId));
            student.setUsername(studentData.get("username"));
            student.setPhone(studentData.get("phone"));
            student.setJavaScore(Integer.parseInt(studentData.get("java")));
            student.setMathScore(Integer.parseInt(studentData.get("math")));

            int javaScore = student.getJavaScore();
            int mathScore = student.getMathScore();
            double avgScore = (javaScore + mathScore) / 2.0;
            student.setAvgScore(avgScore);
            result.add(student);
        }
        return result;
    }
    //(4)
    public static List<Student> sortAvgBySortingParam(int page) {
        List<Student> result = new ArrayList<>();

        try (Jedis jedis = new Jedis("localhost")) {
            int pageSize = 2;
            int start = (page - 1) * pageSize;
            int end = start + pageSize - 1;

            Set<Tuple> sortedStudents = jedis.zrevrangeWithScores("students_average_score", start, end);

            for (Tuple sortedStudent : sortedStudents) {
                String studentId = sortedStudent.getElement();
                String username = jedis.hget("student:" + studentId, "username");
                String phone = jedis.hget("student:" + studentId, "phone");
                String javaScore = jedis.hget("student:" + studentId, "java");
                String mathScore = jedis.hget("student:" + studentId, "math");

                Student student = new Student();
                student.setId(Long.parseLong(studentId));
                student.setUsername(username);
                student.setPhone(phone);
                student.setJavaScore(Integer.parseInt(javaScore));
                student.setMathScore(Integer.parseInt(mathScore));
                result.add(student);
            }
        }
        return result;
    }
    public static void main(String[] args) {
        Scanner scanner=new Scanner(System.in);
        StudentManager StuMan=new StudentManager();
        //(1)
        Student stu=new Student(); //当电话号码重复时,应该抛出异常
        stu.setId(3);   //如果不指定学生的id,那么增加学生的过程中,之前的学生信息会被覆盖掉
        stu.setUsername("zhaoliu");
        stu.setPhone("200207216799");
        stu.setJavaScore(93);
        stu.setMathScore(88);
        StuMan.add(stu);//调用add方法增加学生
        //(2)
        System.out.print("请输入您要查找的学生的名字(如:lisi):");
        String findUsername=scanner.next();
        List<Student> students=StuMan.findByUsername(findUsername);  //调用findbyUsername函数找到符合条件的学生信息
        if(students.isEmpty()){    //输出结果
            System.out.println("未找到用户名为"+findUsername+"的学生。");
        }
        else{
            System.out.println("用户名为"+findUsername+"的学生如下所示:");
            for(Student student:students){
                System.out.println("学生id:"+student.getId());
                System.out.println("学生姓名:"+student.getUsername());
                System.out.println("电话号码: " + student.getPhone());
                System.out.println("Java 分数: " + student.getJavaScore());
                System.out.println("数学分数: " + student.getMathScore());
                System.out.println();
            }
        }
        //(3)
        List<Student> sortStu=StuMan.sortAvg();
        System.out.println("用sorted set按平均成绩降序排序:");
        for(Student student:sortStu){
            System.out.println(student.toString()); //如果不使用toString(),那么输出的结果是对象哈希码
            System.out.println();
        }
        //(4)
        List<Student> Stu = sortAvgBySortingParam(1);
        System.out.println("用SortingParams实现按平均成绩降序排序:");
        for (Student student : Stu) {
            System.out.println(student);
        }
    }
}
【问题简述】:

需要注意点就是使用toString(),因为在将student中的数据输出时,如果不使用toString()方法,那么输出的结果将会是student对象哈希码,那么我们将无法看到正确的输出结果。

;