亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > JSP中的PreparedStatement對象操作數據庫的使用教程

JSP中的PreparedStatement對象操作數據庫的使用教程

熱門標簽:南京新思維電話機器人 南昌市地圖標注app 好操作的電話機器人廠家 地圖標注市場怎么樣 如何用中國地圖標注數字點 泰州泰興400電話 怎么申請 百度地圖添加標注圖標樣式 企業怎么在聯通申請400電話 聊城智能電銷機器人外呼

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>

您可能感興趣的文章:
  • JSP中操作數據庫的常用SQL標簽用法總結
  • jsp從數據庫獲取數據填充下拉框實現二級聯動菜單的方法
  • JSP中使用JDBC訪問SQL Server 2008數據庫示例
  • Java實現JSP在Servelt中連接Oracle數據庫的方法
  • jsp讀取數據庫實現分頁技術簡析
  • jsp 從web.xml讀取連接數據庫的參數
  • JSP連接MySql/MS SQL Server/Oracle數據庫連接方法[整理]
  • Jsp連接Access數據庫(不通過建立ODBC數據源的方法)
  • JSP連接Access數據庫
  • 利用asp或jsp,flash怎樣把數據庫中的一張表中的所有記錄讀取并顯示出來
  • JSP數據庫操數據分頁顯示
  • 在JSP中訪問Oracle數據庫
  • 如何使用JSP訪問MySQL數據庫

標簽:吉林 銅川 山南 自貢 烏蘭察布 開封 白銀 臨汾

巨人網絡通訊聲明:本文標題《JSP中的PreparedStatement對象操作數據庫的使用教程》,本文關鍵詞  JSP,中的,PreparedStatement,對象,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《JSP中的PreparedStatement對象操作數據庫的使用教程》相關的同類信息!
  • 本頁收集關于JSP中的PreparedStatement對象操作數據庫的使用教程的相關信息資訊供網民參考!
  • 推薦文章
    国产极品精频在线观看| 国产国语对白一级毛片| 国产视频一区二区在线观看| 欧美α片无限看在线观看免费| 国产一级强片在线观看| 国产不卡高清在线观看视频| 午夜在线亚洲| 成人高清护士在线播放| 久久国产影院| 国产网站免费视频| 二级片在线观看| 国产精品自拍在线| 国产精品自拍一区| a级精品九九九大片免费看| 国产亚洲精品aaa大片| 欧美激情伊人| 久久99中文字幕| 国产亚洲精品成人a在线| 日韩av片免费播放| 日韩男人天堂| 国产a毛片| 可以在线看黄的网站| 国产韩国精品一区二区三区| 天天做日日干| 久久久久久久免费视频| 国产成人欧美一区二区三区的| 精品视频在线观看视频免费视频| 精品久久久久久中文| 中文字幕一区二区三区 精品 | 国产精品免费久久| 亚洲女初尝黑人巨高清在线观看| 日本在线不卡免费视频一区| 日韩一级精品视频在线观看| 久草免费在线观看| 你懂的在线观看视频| 国产精品自拍一区| a级黄色毛片免费播放视频| 久久精品免视看国产成人2021| 日本免费乱人伦在线观看| 尤物视频网站在线| 日本特黄特黄aaaaa大片| 日韩中文字幕在线观看视频| 黄视频网站免费观看| 麻豆系列国产剧在线观看| 久久国产精品自线拍免费| 国产综合成人观看在线| 久久国产精品只做精品| 久久福利影视| 久久久久久久免费视频| 精品国产香蕉伊思人在线又爽又黄| 欧美激情一区二区三区在线播放 | 国产伦精品一区三区视频| 日韩专区一区| 韩国三级视频网站| 成人高清视频免费观看| 国产一区二区福利久久| 一级毛片看真人在线视频| 精品视频一区二区| 日韩av成人| 国产美女在线一区二区三区| 久草免费在线观看| 国产成人欧美一区二区三区的| 国产亚洲免费观看| 久久国产精品自线拍免费| 夜夜操天天爽| 国产高清在线精品一区a| 亚洲精品影院| 尤物视频网站在线| 久久精品人人做人人爽97| 一级女性全黄生活片免费| 国产一区二区精品久久| 日韩在线观看免费完整版视频| 欧美激情影院| 韩国三级香港三级日本三级| 中文字幕一区二区三区精彩视频 | 成人高清护士在线播放| 国产综合成人观看在线| 国产不卡高清| 国产韩国精品一区二区三区| 国产一区二区高清视频| 日日夜人人澡人人澡人人看免| 久久国产精品永久免费网站| 国产成人欧美一区二区三区的| 韩国毛片基地| 欧美大片一区| 一级女人毛片人一女人| 国产伦理精品| 免费一级片在线观看| 99久久网站| 精品久久久久久综合网| 日本在线播放一区| 尤物视频网站在线观看| 四虎久久影院| 青草国产在线| a级毛片免费观看网站| 天天做人人爱夜夜爽2020毛片| 国产成人精品综合久久久| 美女免费精品高清毛片在线视 | 精品视频在线观看免费| 国产激情一区二区三区| 国产成人精品综合在线| 久久久久久久久综合影视网| 国产一区二区精品| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 国产成人精品综合在线| 精品久久久久久综合网| 999久久狠狠免费精品| 亚洲 男人 天堂| 欧美另类videosbestsex视频| 精品国产三级a| 亚洲精品永久一区| 日韩在线观看视频网站| 日本在线不卡视频| 欧美一级视频免费| 一级女性全黄生活片免费| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 国产一区二区精品| 成人免费一级纶理片| 亚洲女初尝黑人巨高清在线观看| 99久久网站| 青青青草视频在线观看| 欧美另类videosbestsex高清| 毛片成人永久免费视频| 国产a视频| 国产国语对白一级毛片| 午夜久久网| 日本伦理黄色大片在线观看网站| 美国一区二区三区| 日韩中文字幕在线播放| 亚洲第一视频在线播放| 亚洲www美色| 欧美激情一区二区三区在线| 国产成人精品一区二区视频| 99色视频在线| 日韩中文字幕一区二区不卡| 国产网站免费在线观看| 国产视频久久久久| 欧美激情伊人| 成人a级高清视频在线观看| 国产国产人免费视频成69堂| 国产成a人片在线观看视频 | 九九国产| 国产成人欧美一区二区三区的| 一级毛片视频在线观看| 欧美另类videosbestsex高清| 国产91精品露脸国语对白| 欧美大片一区| 欧美激情伊人| 亚飞与亚基在线观看| 精品国产一区二区三区国产馆| 国产视频在线免费观看| 欧美1卡一卡二卡三新区| 欧美激情伊人| 日本免费乱理伦片在线观看2018| 九九国产| 91麻豆精品国产片在线观看| 国产极品精频在线观看| 天天做日日爱夜夜爽| 亚洲第一色在线| 日日夜夜婷婷| 日韩字幕在线| 日韩中文字幕一区| 精品国产亚一区二区三区| 日韩专区亚洲综合久久| 日韩免费在线视频| 青青久久精品| 欧美国产日韩在线| 久久国产影院| 香蕉视频久久| 国产视频一区二区三区四区| 日本伦理网站| 免费毛片播放| 韩国三级一区| 沈樵在线观看福利| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 国产不卡在线看| 日韩欧美一二三区| 中文字幕97| 欧美一级视频免费观看| 日韩字幕在线| 精品在线免费播放| 成人免费观看网欧美片| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 日韩中文字幕在线亚洲一区| 欧美激情一区二区三区视频 | 九九国产| 欧美另类videosbestsex久久| 99色吧| 精品视频在线观看免费| 午夜家庭影院| 久久精品大片| 韩国毛片 免费| 999久久66久6只有精品| 九九国产| 欧美激情伊人| 国产a毛片| 美女免费毛片| 国产美女在线观看| 欧美激情中文字幕一区二区| 国产不卡福利|