5

属性の長いリストを持つ従業員というオブジェクトがあり、データベースから値を取得して従業員オブジェクトに入れる必要があります。次のことを行っていますが、コードが非常に長いため、何かあるかどうか疑問に思っていますそこへのショートカット。

 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

ApacheCommonsBeanProcessorを使用します。これには、toBeanとtoBeanListという2つの非常に便利なメソッドがあります。

この場合、あなたは単にこれをするでしょう:

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

コメントでJigarJoshiが述べたように、ここでは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 に答える