public static String getClassName(Class clazz){ return clazz.getName(); } /** * 获取Entity注解中的表名 */ public static String getTableName(Class clazz){ if (clazz.isAnnotationPresent(Entity.class)){ Entity entity = (Entity) clazz.getAnnotation(Entity.class); return entity.name(); } else { System.out.println("缺少Entity注解"); return null; } } /** * 获取主键属性和对应的字段 */ public static Map<String, String> getIdMapper(Class clazz){ boolean flag=true; Map<String, String> map = new HashMap<>(); Field[] fields = clazz.getDeclaredFields(); for (Field field:fields){ if (field.isAnnotationPresent(Id.class)){ flag=false; String fieldName = field.getName(); if (field.isAnnotationPresent(Column.class)){ Column column = field.getAnnotation(Column.class); String columnName = column.name(); map.put(fieldName,columnName); break; } else { System.out.println("缺少Column注解"); } } } if (flag){ System.out.println("缺少Id注解"); } return map; }
时间: 2024-02-10 10:19:15 浏览: 26
这段代码是用来获取实体类对应的表名和主键属性以及对应的字段名的。其中,getClassName方法用来获取类的全限定名,getTableName方法用来获取实体类对应的表名,getIdMapper方法用来获取主键属性和对应的字段名。这些方法都是静态方法,可以直接通过类名调用。该代码使用了Java反射机制,通过获取类的注解和属性上的注解来获取需要的信息。如果类或属性上缺少必要的注解,则会输出相应的错误信息。
相关问题
public int add(Connection con,SchoolClass schoolClass)throws Exception{ String sql="insert into t_school_class values(null,?,?)"; PreparedStatement pstmt=con.prepareStatement(sql); pstmt.setString(1, schoolClass.getClassName()); System.out.println(schoolClass.getClassName()); pstmt.setString(2, schoolClass.getCalssDesc()); return pstmt.executeUpdate(); } /** * 查询班级集合 * @param con * @param schoolClass * @return * @throws Exception */ public ResultSet list(Connection con,SchoolClass schoolClass)throws Exception{ StringBuffer sb=new StringBuffer("select * from t_school_class"); if(StringUtil.isNotEmpty(schoolClass.getClassName())){ sb.append(" and className like '%"+schoolClass.getClassName()+"%'"); } PreparedStatement pstmt=con.prepareStatement(sb.toString().replaceFirst("and", "where")); return pstmt.executeQuery(); } /** * 删除班级 * @param con * @param id * @return * @throws Exception */ public int delete(Connection con,String id)throws Exception{ String sql="delete from t_school_class where id=?"; PreparedStatement pstmt=con.prepareStatement(sql); pstmt.setString(1, id); return pstmt.executeUpdate(); } /** * 更新班级 * @param con * @param schoolClass * @return * @throws Exception */ public int update(Connection con,SchoolClass schoolClass)throws Exception{ String sql="update t_school_class set className=?,classDesc=? where id=?"; PreparedStatement pstmt=con.prepareStatement(sql); pstmt.setString(1, schoolClass.getClassName()); pstmt.setString(2, schoolClass.getCalssDesc()); pstmt.setInt(3, schoolClass.getId()); return pstmt.executeUpdate(); } }
这段代码看起来像是一个 Java 类中的一些数据库操作方法,这些方法分别是添加班级、查询班级集合、删除班级和更新班级信息。这些方法都需要一个数据库连接对象 Connection 和一个 SchoolClass 类型的参数。其中,添加班级方法使用了 PreparedStatement 预编译 SQL 语句,查询班级集合方法使用了 StringBuffer 拼接 SQL 语句,并使用了 StringUtil 工具类的方法判断字符串是否为空,删除班级方法使用了 PreparedStatement 预编译 SQL 语句并传入一个 ID 参数,更新班级信息方法同样使用了 PreparedStatement 预编译 SQL 语句,并传入一个 SchoolClass 对象的参数。
完善下列代码:// Student.java public class Student { private String name; private int age; // 其他属性和方法 // Getters和Setters } // Teacher.java public class Teacher { private String name; private String subject; // 其他属性和方法 // Getters和Setters } // Class.java public class Class { private String className; private Teacher teacher; private List<Student> students; // 其他属性和方法 // Getters和Setters } // StudentController.java public class StudentController { private StudentView studentView; // 其他属性和方法 // 初始化方法 // 添加学生 public void addStudent(String name, int age) { // 实现逻辑 } // 删除学生 public void deleteStudent(String name) { // 实现逻辑 } // 获取学生列表 public List<Student> getStudents() { // 实现逻辑 } // 其他操作方法 } // TeacherController.java public class TeacherController { private TeacherView teacherView; // 其他属性和方法 // 初始化方法 // 添加教师 public void addTeacher(String name, String subject) { // 实现逻辑 } // 删除教师 public void deleteTeacher(String name) { // 实现逻辑 } // 获取教师列表 public List<Teacher> getTeachers() { // 实现逻辑 } // 其他
好的,我来完善一下代码。以下是完整的代码:
// Student.java
public class Student {
private String name;
private int age;
// 其他属性和方法
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
// Teacher.java
public class Teacher {
private String name;
private String subject;
// 其他属性和方法
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getSubject() {
return subject;
}
public void setSubject(String subject) {
this.subject = subject;
}
}
// Class.java
public class Class {
private String className;
private Teacher teacher;
private List<Student> students;
// 其他属性和方法
public String getClassName() {
return className;
}
public void setClassName(String className) {
this.className = className;
}
public Teacher getTeacher() {
return teacher;
}
public void setTeacher(Teacher teacher) {
this.teacher = teacher;
}
public List<Student> getStudents() {
return students;
}
public void setStudents(List<Student> students) {
this.students = students;
}
}
// StudentController.java
public class StudentController {
private StudentView studentView;
private List<Student> students;
public StudentController() {
studentView = new StudentView();
students = new ArrayList<>();
}
// 添加学生
public void addStudent(String name, int age) {
Student student = new Student();
student.setName(name);
student.setAge(age);
students.add(student);
}
// 删除学生
public void deleteStudent(String name) {
for (Student student : students) {
if (student.getName().equals(name)) {
students.remove(student);
break;
}
}
}
// 获取学生列表
public List<Student> getStudents() {
return students;
}
// 其他操作方法
}
// TeacherController.java
public class TeacherController {
private TeacherView teacherView;
private List<Teacher> teachers;
public TeacherController() {
teacherView = new TeacherView();
teachers = new ArrayList<>();
}
// 添加教师
public void addTeacher(String name, String subject) {
Teacher teacher = new Teacher();
teacher.setName(name);
teacher.setSubject(subject);
teachers.add(teacher);
}
// 删除教师
public void deleteTeacher(String name) {
for (Teacher teacher : teachers) {
if (teacher.getName().equals(name)) {
teachers.remove(teacher);
break;
}
}
}
// 获取教师列表
public List<Teacher> getTeachers() {
return teachers;
}
// 其他操作方法
}
// StudentView.java
public class StudentView {
public void displayStudentList(List<Student> students) {
for (Student student : students) {
System.out.println("Name: " + student.getName() + ", Age: " + student.getAge());
}
}
// 其他视图方法
}
// TeacherView.java
public class TeacherView {
public void displayTeacherList(List<Teacher> teachers) {
for (Teacher teacher : teachers) {
System.out.println("Name: " + teacher.getName() + ", Subject: " + teacher.getSubject());
}
}
// 其他视图方法
}
在这个代码中,我为每个类添加了Getter和Setter方法,并为StudentController和TeacherController类添加了逻辑,包括添加、删除和获取学生/教师列表等方法。我还添加了两个视图类StudentView和TeacherView,用于显示学生和教师列表。这个代码可能还需要更多的逻辑,具体取决于您的需求。