1

这是我遇到错误的 SQL Connection 类的代码。

public class SqlConnection {
    static Connection con;
.......

    static public ResultSet getData(String sql, List<LogModel> alist)
            throws ClassNotFoundException, SQLException {
        PreparedStatement pst = con.prepareStatement(sql);
        if (alist != null) {
            for (int i = 1; i <= alist.size(); i++) {
                pst.setObject(i, alist.get(i-1)); //Exception at this Line
            }
        }
        ResultSet rs = pst.executeQuery();
        return rs;
    }
}

这是LogAction我调用此getdata()函数的类。

public class LogAction extends ActionSupport implements ModelDriven<LogModel>, Preparable {

    LogModel log = null;
    List<LogModel> alist = null;
    public static final String FAILURE = "failure";

    @Override
    public void prepare() throws Exception {
        log = new LogModel();
        alist = new ArrayList<LogModel>();
    }

    @Override
    public LogModel getModel() {
        return log;
    }

    public String login() throws ClassNotFoundException, SQLException {
        String sql = "Select username,password from registration where username=? and password=?";
        alist.add(log);
        System.out.println(alist);
        ResultSet rs = SqlConnection.getData(sql, alist);
        if (rs.next()) {
            return SUCCESS;
        } else
            return FAILURE;
    }
}
4

2 回答 2

0

我确信 PreparedStatement 不知道如何在您的 LogModel 上设置对象。我的建议是将其分解为 SQL 原语,以便它知道如何处理它。

您的代码需要大量工作。您没有正确关闭 JDBC 资源。您的 LogAction 类没有意义。这一点代码有很多错误。我会担心你的应用程序。

于 2013-06-20T11:57:05.940 回答
0

将您的代码修改为

static public ResultSet getData(String sql, String username, String password)
        throws ClassNotFoundException, SQLException {
    PreparedStatement pst = con.prepareStatement(sql);
    pst.setString(1, username);
    pst.setString(2, password);
    ResultSet rs = pst.executeQuery();
    return rs;
}

将模型对象设置为准备好的语句的参数是没有意义的。

于 2013-06-20T12:15:05.333 回答