JSP中的PreparedStatement對象操作資料庫的使用教程_JSP編程

來源:互聯網
上載者:User

PreparedStatement介面繼承Statement,並與之在兩方面有所不同:
PreparedStatement 執行個體包含已編譯的 SQL 陳述式。這就是使語句“準備好”。包含於 PreparedStatement 對象中的 SQL 陳述式可具有一個或多個 IN 參數。IN參數的值在 SQL 陳述式建立時未被指定。相反的,該語句為每個 IN 參數保留一個問號(“?”)作為預留位置。每個問號的值必須在該語句執行之前,通過適當的setXXX 方法來提供。
由於 PreparedStatement 對象已先行編譯過,所以其執行速度要快於 Statement 對象。因此,多次執行的 SQL 陳述式經常建立為 PreparedStatement 對象,以提高效率。
作為 Statement 的子類,PreparedStatement 繼承了 Statement 的所有功能。另外它還添加了一整套方法,用於設定發送給資料庫以取代 IN 參數預留位置的值。同時,三種方法 execute、 executeQuery 和 executeUpdate 已被更改以使之不再需要參數。這些方法的 Statement 形式(接受 SQL 陳述式參數的形式)不應該用於 PreparedStatement 對象。
1、建立 PreparedStatement 對象
以下的程式碼片段(其中 con 是 Connection 對象)建立包含帶兩個 IN 參數預留位置的 SQL 陳述式的 PreparedStatement 對象:
PreparedStatement pstmt = con.prepareStatement("UPDATE table4 SET m = ? WHERE x = ?");
pstmt 對象包含語句 "UPDATE table4 SET m = ? WHERE x = ?",它已發送給DBMS,並為執行作好了準備。
2、傳遞 IN 參數
在執行 PreparedStatement 對象之前,必須設定每個 ? 參數的值。這可通過調用 setXXX 方法來完成,其中 XXX 是與該參數相應的類型。例如,如果參數具有Java 類型 long,則使用的方法就是 setLong。setXXX 方法的第一個參數是要設定的參數的序數位置,第二個參數是設定給該參數的值。例如,以下代碼將第一個參數設為 123456789,第二個參數設為 100000000:

pstmt.setLong(1, 123456789);pstmt.setLong(2, 100000000);

一旦設定了給定語句的參數值,就可用它多次執行該語句,直到調用clearParameters 方法清除它為止。在串連的預設模式下(啟用自動認可),當陳述式完成時將自動認可或還原該語句。
如果基本資料庫和驅動程式在語句提交之後仍保持這些語句的開啟狀態,則同一個 PreparedStatement 可執行多次。如果這一點不成立,那麼試圖通過使用PreparedStatement 對象代替 Statement 對象來提高效能是沒有意義的。
利用 pstmt(前面建立的 PreparedStatement 對象),以下代碼例示了如何設定兩個參數預留位置的值並執行 pstmt 10 次。如上所述,為做到這一點,資料庫不能關閉 pstmt。在該樣本中,第一個參數被設定為 "Hi"並保持為常數。在 for 迴圈中,每次都將第二個參數設定為不同的值:從 0 開始,到 9 結束。

pstmt.setString(1, "Hi");for (int i = 0; i < 10; i++) { pstmt.setInt(2, i); int rowCount = pstmt.executeUpdate();}

3、IN 參數中資料類型的一致性
setXXX 方法中的 XXX 是 Java 類型。它是一種隱含的 JDBC 類型(一般 SQL 類型),因為驅動程式將把 Java 類型映射為相應的 JDBC 類型(遵循該 JDBCGuide中§8.6.2 “映射 Java 和 JDBC 類型”表中所指定的映射),並將該 JDBC 類型發送給資料庫。例如,以下程式碼片段將 PreparedStatement 對象 pstmt 的第二個參數設定為 44,Java 類型為 short:
pstmt.setShort(2, 44);
驅動程式將 44 作為 JDBC SMALLINT 發送給資料庫,它是 Java short 類型的標準映射。
程式員的責任是確保將每個 IN 參數的 Java 類型映射為與資料庫所需的 JDBC 資料類型相容的 JDBC 類型。不妨考慮資料庫需要 JDBC SMALLINT 的情況。如果使用方法 setByte ,則驅動程式將 JDBC TINYINT 發送給資料庫。這是可行的,因為許多資料庫可從一種相關的類型轉換為另一種類型,並且通常 TINYINT 可用於SMALLINT 適用的任何地方
預先處理語句對象PreparedStatement,使用PreparedStatement進行添加資料,更新資料,刪除資料和查詢資料

執行個體:
1.添加資料

<%@page language="java" contentType="text/html;charset=gb2312"%><%@page import="java.sql.*" %><!DOCTYPE html><html>  <head>    <title>獲得第二條記錄開始的三條記錄</title>  </head>  <body>    <%      String url = "jdbc:mysql://localhost:3306/javaweb";//串連資料庫的url地址      String user = "root";//登入資料庫的使用者名稱      String password = "zhangda890126;;";//登入資料庫的使用者名稱的密碼      Connection conn = null;//連結化物件      PreparedStatement pstmt = null;//語句對象      //ResultSet rs = null;//結果集對象      try{        Class.forName("com.mysql.jdbc.Driver");//載入JDBC驅動程式        conn = DriverManager.getConnection(url,user,password);//連結資料庫      }catch(ClassNotFoundException e){        out.println("找不到驅動類");//拋出異常時,提示資訊      }catch(SQLException e){        out.println("連結MySQL資料庫失敗");//處理SQLException異常      }      try{        String adduser = "INSERT INTO user (userid,username,password) VALUES(null,?,?)";//添加一條使用者資訊        pstmt = conn.<span style="color:#e53333;"><b>prepareStatement</b></span>(adduser);//建立預先處理語句對象PreparedStatement                 //設定參數        pstmt.setString(1,"YAO");        pstmt.setString(2,"yao");                 //執行語句        pstmt.executeUpdate();               }catch(SQLException e){        out.println("添加使用者資訊失敗");      }             try{        if(pstmt != null){          pstmt.close();          conn = null;        }        if(conn != null){          conn.close();          conn = null;        }      }catch(Exception e){               out.println("資料庫關閉失敗");      }    %>  </body></html>

提示一下一定不要用錯大小寫,紅色標記就是因為我前面的字母大寫,花費了很長時間

2.更新資料

<%@page language="java" contentType="text/html;charset=gb2312"%><%@page import="java.sql.*" %><!DOCTYPE html><html>  <head>    <title>獲得第二條記錄開始的三條記錄</title>  </head>  <body>    <%      String url = "jdbc:mysql://localhost:3306/javaweb";//串連資料庫的url地址      String user = "root";//登入資料庫的使用者名稱      String password = "zhangda890126;;";//登入資料庫的使用者名稱的密碼      Connection conn = null;//連結化物件      PreparedStatement pstmt = null;//語句對象      //ResultSet rs = null;//結果集對象      try{        Class.forName("com.mysql.jdbc.Driver");//載入JDBC驅動程式        conn = DriverManager.getConnection(url,user,password);//連結資料庫      }catch(ClassNotFoundException e){        out.println("找不到驅動類");//拋出異常時,提示資訊      }catch(SQLException e){        out.println("連結MySQL資料庫失敗");//處理SQLException異常      }      try{        String updateuser = "UPDATE user SET password = ? WHERE userid = ?";//添加一條使用者資訊        pstmt = conn.prepareStatement(updateuser);//建立預先處理語句對象PreparedStatement                 //設定參數        pstmt.setString(1,"hello world");        pstmt.setInt(2,1);                 //執行語句        pstmt.executeUpdate();               }catch(SQLException e){        out.println("添加使用者資訊失敗");      }             try{        if(pstmt != null){          pstmt.close();          conn = null;        }        if(conn != null){          conn.close();          conn = null;        }      }catch(Exception e){               out.println("資料庫關閉失敗");      }    %>  </body></html>

3.刪除資料

<%@page language="java" contentType="text/html;charset=gb2312"%><%@page import="java.sql.*" %><!DOCTYPE html><html>  <head>    <title>獲得第二條記錄開始的三條記錄</title>  </head>  <body>    <%      String url = "jdbc:mysql://localhost:3306/javaweb";//串連資料庫的url地址      String user = "root";//登入資料庫的使用者名稱      String password = "zhangda890126;;";//登入資料庫的使用者名稱的密碼      Connection conn = null;//連結化物件      PreparedStatement pstmt = null;//語句對象      //ResultSet rs = null;//結果集對象      try{        Class.forName("com.mysql.jdbc.Driver");//載入JDBC驅動程式        conn = DriverManager.getConnection(url,user,password);//連結資料庫      }catch(ClassNotFoundException e){        out.println("找不到驅動類");//拋出異常時,提示資訊      }catch(SQLException e){        out.println("連結MySQL資料庫失敗");//處理SQLException異常      }      try{        String deleteuser = "DELETE FROM user WHERE userid = ?";//添加一條使用者資訊        pstmt = conn.prepareStatement(deleteuser);//建立預先處理語句對象PreparedStatement                 //設定參數        pstmt.setInt(1,2);                 //執行語句        pstmt.executeUpdate();               }catch(SQLException e){        out.println("添加使用者資訊失敗");      }             try{        if(pstmt != null){          pstmt.close();          conn = null;        }        if(conn != null){          conn.close();          conn = null;        }      }catch(Exception e){               out.println("資料庫關閉失敗");      }    %>  </body></html>

4.查詢資料

<%@page language="java" contentType="text/html;charset=gb2312"%><%@page import="java.sql.*" %><!DOCTYPE html><html>  <head>    <title>獲得第二條記錄開始的三條記錄</title>  </head>  <body>    <%      String url = "jdbc:mysql://localhost:3306/javaweb";//串連資料庫的url地址      String user = "root";//登入資料庫的使用者名稱      String password = "zhangda890126;;";//登入資料庫的使用者名稱的密碼      Connection conn = null;//連結化物件      PreparedStatement pstmt = null;//語句對象      ResultSet rs = null;//結果集對象      try{        Class.forName("com.mysql.jdbc.Driver");//載入JDBC驅動程式        conn = DriverManager.getConnection(url,user,password);//連結資料庫      }catch(ClassNotFoundException e){        out.println("找不到驅動類");//拋出異常時,提示資訊      }catch(SQLException e){        out.println("連結MySQL資料庫失敗");//處理SQLException異常      }      try{        String queryAll = "SELECT * FROM user LIMIT ?,?;";//添加一條使用者資訊        pstmt = conn.prepareStatement(queryAll);//建立預先處理語句對象PreparedStatement                 //設定參數        pstmt.setInt(1,2);        pstmt.setInt(2,5);                 //執行語句        rs = pstmt.executeQuery();                 while(rs.next()){          int userid = rs.getInt(1);          String username = rs.getString(2);          String userpassword = rs.getString(3);          out.println("使用者的ID:"+userid+"使用者名稱:"+username+"使用者的密碼:"+userpassword+"<br />");        }               }catch(SQLException e){        out.println("添加使用者資訊失敗");      }             try{        if(pstmt != null){          pstmt.close();          conn = null;        }        if(conn != null){          conn.close();          conn = null;        }      }catch(Exception e){               out.println("資料庫關閉失敗");      }    %>  </body></html>

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.