亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JSP > 正文

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

2024-09-05 00:22:31
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了JSP中的PreparedStatement對象操作數據庫的使用教程,文中舉了一些使用PreparedStatement預處理語句對象進行MySQL增刪查改的例子,需要的朋友可以參考下
 

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教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
午夜精品三级视频福利| 韩国精品美女www爽爽爽视频| 国产在线观看精品一区二区三区| 国产精品普通话| 国产91精品久久久久久| 日韩在线视频观看| 日韩人体视频一二区| 久久精品国产亚洲精品2020| 欧美限制级电影在线观看| 黑人狂躁日本妞一区二区三区| 美女999久久久精品视频| 成人国产亚洲精品a区天堂华泰| 日韩电影中文字幕| 日韩中文字幕精品视频| 日韩精品一区二区视频| 欧美性猛交xxxx免费看漫画| 日韩av在线高清| 38少妇精品导航| 成人高h视频在线| 欧美精品aaa| 在线免费观看羞羞视频一区二区| 国产欧美在线播放| 久热精品视频在线免费观看| 日韩美女福利视频| 3344国产精品免费看| 亚洲精品视频在线播放| 91老司机精品视频| 国产日韩在线亚洲字幕中文| 精品国产欧美一区二区五十路| 国产91精品在线播放| 国产精品久久久久av| 亚洲精品午夜精品| 97福利一区二区| 日韩电影中文字幕在线观看| 国产伦精品一区二区三区精品视频| 日韩精品亚洲视频| 欧美精品免费在线观看| 欧美激情亚洲精品| 黄色精品一区二区| 欧美精品做受xxx性少妇| 91精品国产综合久久久久久蜜臀| 亚洲一区二区自拍| 亚洲精品国产精品国产自| 91av在线不卡| 欧美丰满老妇厨房牲生活| 中文字幕日韩免费视频| 久久亚洲综合国产精品99麻豆精品福利| 国内精品久久久久久中文字幕| 国产91在线播放九色快色| 日韩av在线天堂网| 97超级碰碰人国产在线观看| 久久这里有精品视频| 青青草原成人在线视频| 久久精品久久久久电影| 精品日韩美女的视频高清| 亚洲第一男人天堂| 精品久久久久久国产| 久久久精品免费| 国外色69视频在线观看| 亚洲女人天堂av| 丝袜一区二区三区| 亚洲成年人在线播放| 亚洲一区二区三区在线视频| 欧美性黄网官网| 久久伊人91精品综合网站| 中文字幕无线精品亚洲乱码一区| 欧美日韩成人在线播放| 亚洲国语精品自产拍在线观看| 国产视频久久久| 日韩成人中文字幕在线观看| 欧美大全免费观看电视剧大泉洋| 国内精品久久久久伊人av| 最近2019中文字幕mv免费看| 日韩大片在线观看视频| 日韩精品免费在线观看| 国产亚洲精品一区二555| 国产精品入口夜色视频大尺度| 亚洲视频电影图片偷拍一区| 久久91亚洲精品中文字幕奶水| 51久久精品夜色国产麻豆| 欧美日韩第一页| 国外成人在线视频| 亚洲18私人小影院| www高清在线视频日韩欧美| 久久精品国产久精国产一老狼| 亚洲欧美一区二区三区情侣bbw| 欧美在线视频观看免费网站| 亚洲一区制服诱惑| 91精品视频免费看| 亚洲已满18点击进入在线看片| 精品二区三区线观看| 亚洲欧美制服第一页| 国产在线视频一区| 亚洲一区二区久久久久久| 国产在线视频欧美| 欧美国产日韩一区| 亚洲国产高清自拍| 亚洲福利视频久久| 琪琪第一精品导航| 日韩中文在线中文网三级| 久久久精品免费| 欧美日本高清一区| 亚洲欧美制服中文字幕| 国产精品久久久久久久7电影| 九九九热精品免费视频观看网站| 97激碰免费视频| 日韩精品视频观看| 国产午夜精品久久久| 国产一区在线播放| 日韩视频永久免费观看| 美女国内精品自产拍在线播放| 亚洲最大成人免费视频| 欧美另类极品videosbestfree| 国产精品露脸av在线| 中日韩美女免费视频网站在线观看| 国产一区二区三区毛片| 自拍偷拍亚洲在线| 一个人www欧美| 国产精品一区二区三区在线播放| 亚洲一区二区三区sesese| 成人网址在线观看| 国产精品jvid在线观看蜜臀| 欧洲美女免费图片一区| 成人福利在线视频| 欧美精品videos另类日本| 日韩电影中文字幕av| 2019中文字幕免费视频| 欧美另类99xxxxx| 成人精品视频99在线观看免费| 国产69久久精品成人看| 26uuu另类亚洲欧美日本老年| 操91在线视频| 欧美日韩国产中字| …久久精品99久久香蕉国产| 精品国产精品三级精品av网址| 亚洲第一精品夜夜躁人人爽| 亚洲精品国产精品国产自| 欧美日韩免费在线观看| 国产一区二区在线播放| 97国产精品人人爽人人做| 一夜七次郎国产精品亚洲| 久久理论片午夜琪琪电影网| 欧洲美女7788成人免费视频| 2019中文字幕免费视频| 狠狠躁夜夜躁人人躁婷婷91| 欧美国产亚洲视频| 亚洲视频日韩精品| 国外成人免费在线播放| 国模精品一区二区三区色天香| 国产成人一区二区在线| 91精品久久久久久综合乱菊| 国精产品一区一区三区有限在线| 91高清免费视频| 欧美激情在线观看| 亚洲国产精品va在线| 国产精品日韩av| 高清欧美性猛交xxxx| 日韩在线观看免费高清| 黑人精品xxx一区一二区| 欧美激情精品久久久久久蜜臀| 成人激情在线播放| 亚洲欧美一区二区三区四区| 中日韩美女免费视频网站在线观看| 亚洲另类欧美自拍|