我试图使一个jsp从“ update.jsp”上的表单中获取用户输入,并运行一条update语句来更新数据库条目并在“ display.jsp”上显示结果。
我使用eclipse作为我的IDE,使用oracle作为我的数据库服务器
以前,我已经成功执行了一条select语句(作为测试)。因此,请确保与数据库的连接没有问题
这是代码正在用于“ update.jsp”(窗体)的代码

<FORM ACTION="display.jsp">
    <label>Semester:
        <select name="semester_form">
            <option selected="semester">Semester Select</option>
            <%//public String input_semester=semester; %>

            <option value='Spring'>Springy</option>
            <option value='January Intersession'>January Intersession</option>
            <option value='Fall'>Fall</option>
            <option value='Summer ALL'>Summer ALL</option>
            <option value='Summer00'>Summer00</option>
            <option value='Summer02'>Summer02</option>
            <option value='Summer01'>Summer01</option>


这是我在创建数据库时使用的代码

CREATE TABLE SEMESTER_SCHEDULE_READER (
    SEMESTER_ID     VARCHAR2(2) NULL,
    START_DATE      DATE NULL,
    END_DATE        DATE NULL,
    SEMESTER_NAME   VARCHAR2(25) NULL,
    SEMESTER        VARCHAR2(8) NULL
)


现在这是正在使用的“ display.JSP”代码

Connection conn = null;
try {
    // 1. Load the driver
    Class.forName(driver);

    // myusername and mypassword are declared in a file called username.jsp

    // 2. Define the connection URL
    // 3. Establish the connection
    conn = DriverManager.getConnection(
            url,
            myusername,
            mypassword);


    // 4. Create a statement object
    Statement stmt = conn.createStatement();
    PreparedStatement pstatement = null;
    int updateQuery = 0;

    // 5. Execute a query

    String semester = request.getParameter("semester_form");
    session.putValue("semester_form", semester);
    String start_date = request.getParameter("startDate_form");
    String end_date = request.getParameter("endDate_form");
    //ResultSet rs = stmt.executeQuery("select * from SEMESTER_SCHEDULE_READER  where semeStER_NAME='"+semester+"'");
    conn.setAutoCommit(false);

    ResultSet rs = stmt.executeQuery("UPDATE SEMESTER_SCHEDULE_READER SET START_DATE= to_date('" + start_date + "', 'DD-MON-YY') WHERE SEMESTER='" + semester + "'");

    conn.commit();


    // printing a welcom message
    out.println("<H1>You have successfully updated the semester schedule</H1><br>");

    //Print start of table and column headers
    out.println("<TABLE width = 600 CELLSPACING=\"0\" CELLPADDING=\"3\" BORDER=\"2\">");
    out.println("<TR><TH>Semester Name</TH><TH>Start date</TH><TH>End date</TH></TR>");

    // 6. Process result
    //column names and Data types has to match Db columns
    while (rs.next()) {
        out.println("<TR>");
        out.println("<TD>" + rs.getString("SEMESTER_NAME") + "</TD>");
        out.println("<TD>" + rs.getString("START_DATE") + "</TD>");
        out.println("<TD>" + rs.getString("END_DATE") + "</TD>");


        out.println("</TR>");
    }

    out.println("</TABLE>");
} catch (SQLException e) {
    // Do exception catch such as if connection is not made or
    // query is not set up properly
    out.println("SQLException: " + e.getMessage() + "<BR>");
    while ((e = e.getNextException()) != null)
        out.println(e.getMessage() + "<BR>");
} catch (ClassNotFoundException e) {
    out.println("ClassNotFoundException: " + e.getMessage() + "<BR>");
} finally {
    // 7. Close connection; Clean up resources
    if (conn != null) {
        try {
            conn.close();
        } catch (Exception ignored) {
        }
    }
}
 %>

最佳答案

ResultSet rs = stmt.executeQuery(...)


应该替换为

int results = stmt.executeUpdate(...)


executeQuery在执行查询(选择)时使用,但executeUpdate在执行将更改数据库的内容(插入,更新,删除)时使用。

10-06 14:03
查看更多