gpt4 book ai didi

java - 行映射器是最好的吗?

转载 作者:行者123 更新时间:2023-12-02 06:09:28 25 4
gpt4 key购买 nike

我在jsp中使用resultset类从mysql获取数据库信息。现在我正在工作Spring MVC。那么我会用什么呢?结果集还是行映射器?

行映射器

public class UserRowMapper implements RowMapper<User> {

@Override
public User mapRow(ResultSet resultSet, int line) throws SQLException {
UserExtractor userExtractor = new UserExtractor();
return userExtractor.extractData(resultSet);
}

}

public class UserExtractor implements ResultSetExtractor<User> {

public User extractData(ResultSet resultSet) throws SQLException, DataAccessException {

User user = new User();

user.setUserId(resultSet.getInt(1));
user.setFirstName(resultSet.getString(2));
user.setLastName(resultSet.getString(3));
user.setGender(resultSet.getString(4));
user.setCity(resultSet.getString(5));

return user;
}
}

最佳答案

RowMapperResultSetExtractor 之间的主要区别是您的问题似乎忽略的内容:

  • RowMapper 每行生成一个对象;
  • ResultSetExtractor 为整个 ResultSet 生成一个对象。

因此,假设一个结果行代表一个用户,ResultSetExtractor 的返回类型不能为 User

通常,当可以支持您的用例时,更喜欢 RowMapper。如果您的最终结果是 User 对象的列表,则无需手动对 ResultSet 进行迭代,添加到您必须创建的列表中,即您需要使用 ResultSetExtractor 做什么。

关于java - 行映射器是最好的吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22011047/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com