import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; import java.util.ArrayList; import java.util.List; //import Account.java; public class JDBCResultSet<Stu> { public void testResultSet() throws Exception { Class.forName("com.mysql.jdbc.Driver"); String url = "jdbc:mysql:///test01?useSSL=false"; String username = "root"; String password = "03928"; Connection conn = DriverManager.getConnection(url, username, password); String sql = "select * from account"; Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery(sql); List<Stu> list = new ArrayList<>(); while (rs.next()){ Stu student = new Stu(); } } }出现Type parameter 'Stu' cannot be instantiated directly这个错误如何处理
时间: 2024-02-01 10:04:52 浏览: 361
在您的代码中,`Stu`是一个泛型类型参数,它不能被直接实例化。因此,在这里创建`Stu`的实例会导致编译错误。
如果您想要将查询结果集映射到一个类型为`Stu`的对象列表中,您需要做以下几件事:
1. 定义一个具体的类来表示您想要映射的对象,例如:
```
public class Student {
private int id;
private String name;
// ...
public Student(int id, String name) {
this.id = id;
this.name = name;
}
// ...
}
```
2. 在您的方法中,使用`ResultSet`对象来获取查询结果集中的数据,并将其映射到您定义的对象中,例如:
```
List<Student> list = new ArrayList<>();
while (rs.next()) {
int id = rs.getInt("id");
String name = rs.getString("name");
Student student = new Student(id, name);
list.add(student);
}
```
在这个例子中,我们使用`ResultSet`对象的`getInt()`和`getString()`方法来获取查询结果集中的数据,并将其映射到`Student`对象中。最后,我们将`Student`对象添加到一个`List<Student>`中。
请注意,这只是一个示例。实际上,您需要根据您的需求定义一个适合您的类,并将查询结果映射到这个类的实例中。
阅读全文