5

我有一个名为employee 的对象,它有很长的属性列表,我正在从数据库中检索值并需要将它们放入employee 对象中,我正在执行以下操作,但是由于代码太长,我想知道是否有任何它的捷径。

 Employee emp = new Employee();
        try {

             ps = con.prepareStatement("select * from Employee WHERE username = ?");

            ps.setString(1, username);
            ResultSet r = ps.executeQuery();
 if (r.next()) {

        // 12 lines to put values into employee object need to be shorter            
        emp.setID(r.getInt(1));
        emp.setTitle(r.getString(2));
        emp.setFname(r.getString(3));
        emp.setLname(r.getString(4));
        emp.setMobile(r.getString(5));
        emp.setPhone(r.getString(6));
        emp.setEmail(r.getString(7));
        emp.setPosition(r.getString(8));
        emp.setUsername(r.getString(9));
        emp.setPassword(r.getString(10));
        emp.setQuestion(r.getString(11));
        emp.setAnswer(r.getString(12));

 }
 }.....
4

2 回答 2

2

使用 Apache Commons BeanProcessor。它有两个非常有用的方法,分别是 toBean 和 toBeanList。

在这种情况下,您只需执行以下操作:

if (r.next()) {
    BeanProcessor bp = new BeanProcessor();
    emp = bp.toBean(r, Employee.class);
}
于 2013-02-18T03:44:03.587 回答
0

正如 Jigar Joshi 在评论中提到的,像Hibernate这样的 ORM 框架将是一个不错的选择。

这是一个帮助您入门的示例。

http://docs.jboss.org/hibernate/orm/4.1/quickstart/en-US/html_single/#hibernate-gsg-tutorial-basic-test-list

于 2013-02-18T03:42:24.033 回答