如何从 java 中的 ResultSet 中检索对象?
How to retrieve an object from ResultSet in java?
所以我尝试制作一个 getRecord class 以根据用户输入的 ID 从数据库中检索信息,
public Student getRecord(String id) {
String queryStr = "SELECT * FROM " + tableName + " WHERE ID = ?";
Student student = null;
try {
stmt = conn.prepareStatement(queryStr);
stmt.setString(1, id);
ResultSet rs = stmt.executeQuery();
int count = 1;
if (rs.next()) {
String level = rs.getString("Level");
char level1 = level.charAt(0);
student = new Student(id, rs.getString("IC"), rs.getString("Name"), level1, rs.getObject("ProgrammeCode"), Integer.parseInt(rs.getString("Yr")));
}
} catch (SQLException ex) {
JOptionPane.showMessageDialog(null, ex.getMessage(), "ERROR", JOptionPane.ERROR_MESSAGE);
}
return student;
}
所以它运行查询并调用student的构造函数,
public Student(String id, String ic, String name, char level, Programme programme, int year) {
this.id = id;
this.ic = ic;
this.name = name;
this.level = level;
this.programme = programme;
this.year = year;
}
为学生class创建一个对象,然后return它到主程序。但是,学生构造函数还需要另一个程序对象。如何通过 ResultSet 从数据库中检索对象?我已经坚持了几个小时并尝试使用 getObject 但它没有用。请指导我。 TQ,祝你有美好的一天。
解决方案感谢@Joop Eggen
我设法通过声明和初始化一个新对象来解决这个问题,替换 rs.getString("ProgrammeCode");到(新程序(rs.getString(“ProgrammeCode”)))。
所以我尝试制作一个 getRecord class 以根据用户输入的 ID 从数据库中检索信息,
public Student getRecord(String id) {
String queryStr = "SELECT * FROM " + tableName + " WHERE ID = ?";
Student student = null;
try {
stmt = conn.prepareStatement(queryStr);
stmt.setString(1, id);
ResultSet rs = stmt.executeQuery();
int count = 1;
if (rs.next()) {
String level = rs.getString("Level");
char level1 = level.charAt(0);
student = new Student(id, rs.getString("IC"), rs.getString("Name"), level1, rs.getObject("ProgrammeCode"), Integer.parseInt(rs.getString("Yr")));
}
} catch (SQLException ex) {
JOptionPane.showMessageDialog(null, ex.getMessage(), "ERROR", JOptionPane.ERROR_MESSAGE);
}
return student;
}
所以它运行查询并调用student的构造函数,
public Student(String id, String ic, String name, char level, Programme programme, int year) {
this.id = id;
this.ic = ic;
this.name = name;
this.level = level;
this.programme = programme;
this.year = year;
}
为学生class创建一个对象,然后return它到主程序。但是,学生构造函数还需要另一个程序对象。如何通过 ResultSet 从数据库中检索对象?我已经坚持了几个小时并尝试使用 getObject 但它没有用。请指导我。 TQ,祝你有美好的一天。
解决方案感谢@Joop Eggen
我设法通过声明和初始化一个新对象来解决这个问题,替换 rs.getString("ProgrammeCode");到(新程序(rs.getString(“ProgrammeCode”)))。