JDBC中的PreparedStatement是什麼?

WBOY
發布: 2023-09-11 09:09:09
轉載
1416 人瀏覽過

JDBC中的PreparedStatement是什麼?

PreparedStatement介面擴充了Statement接口,它代表一個可以執行多次的預編譯SQL語句。它接受參數化 SQL 查詢,並且您可以向此查詢傳遞 0 個或多個參數。

最初此語句使用佔位符“?” 而不是參數,稍後您可以傳遞參數使用PreparedStatement 介面的setXXX() 方法動態地實作這些。

建立一個PreparedStatement

您可以建立一個PreparedStatement (介面)使用 Connection 介面的 prepareStatement() 方法。此方法接受查詢(參數化)並傳回一個PreparedStatement 物件。

當您呼叫此方法時,Connection 物件會將給定的查詢傳送到資料庫以編譯並儲存它。如果查詢編譯成功,則僅傳回物件。

要編譯查詢,資料庫不需要任何值,因此您可以使用(零個或多個)佔位符 (問號」 ?”) 來取代查詢中的值。

例如,如果資料庫中有一個名為 Employee 的表,使用下列查詢建立。

CREATE TABLE Employee(Name VARCHAR(255), Salary INT NOT NULL, Location VARCHAR(255));
登入後複製

然後您應該可以使用準備好的語句向其中插入值,如下所示。

//Creating a Prepared Statement
String query="INSERT INTO Employee(Name, Salary, Location)VALUES(?, ?, ?)";
Statement pstmt = con.prepareStatement(query);
登入後複製

設定佔位符的值

PreparedStatement介面提供了幾個setter方法,例如setInt()、setFloat()、setArray()、setDate() 、setDouble()等,用來設定預編譯語句的佔位符的值。

這些方法接受兩個參數,一個是表示佔位符位置索引的整數值,另一個是int、String、float等表示您需要插入的值。

您可以使用以下範例中的setter方法為上述建立的語句設定佔位符的值:

pstmt.setString(1, "Amit");
pstmt.setInt(2, 3000);
pstmt.setString(3, "Hyderabad");

pstmt.setString(1, "Kalyan");
pstmt.setInt(2, 4000);
pstmt.setString(3, "Vishakhapatnam");

pstmt.setString(1, "Renuka");
pstmt.setInt(2, 5000);
pstmt.setString(3, "Delhi");

pstmt.setString(1, "Archana");
pstmt.setInt(2, 15000);
pstmt.setString(3, "Mumbai");
登入後複製

執行Prepared Statement

建立PreparedStatement物件後,您可以使用PreparedStatement介面的execute()方法之一來執行它,即execute ()executeUpdate() 和、executeQuery()。

  • execute(): 此方法在目前準備好的語句物件中執行普通的靜態 SQL 語句,並傳回一個布林值。

  • executeQuery(): 該方法執行

  • executeUpdate():該方法在當前Prepared中執行insert update或delete等SQL DML語句陳述。它傳回一個整數值,表示受影響的行數。

您可以執行上面建立的準備好的語句,如下所示:

範例

在本例中,我們嘗試使用準備好的語句將值插入名為「Employees」的表中。

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;
public class PreparedStatementExample {
   public static void main(String args[]) throws SQLException {
      //Registering the Driver
      DriverManager.registerDriver(new com.mysql.jdbc.Driver());

      //Getting the connection
      String mysqlUrl = "jdbc:mysql://localhost/testdb";
      Connection con = DriverManager.getConnection(mysqlUrl, "root", "password");
      System.out.println("Connection established......");

      //Creating a Prepared Statement
      String query = "INSERT INTO Employees(Name, Salary, Location) VALUES (?, ?, ?)";
      PreparedStatement pstmt = con.prepareStatement(query);

      pstmt.setString(1, "Amit");
      pstmt.setInt(2, 3000);
      pstmt.setString(3, "Hyderabad");

      pstmt.setString(1, "Kalyan");
      pstmt.setInt(2, 4000);
      pstmt.setString(3, "Vishakhapatnam");

      pstmt.setString(1, "Renuka");
      pstmt.setInt(2, 5000);
      pstmt.setString(3, "Delhi");

      pstmt.setString(1, "Archana");
      pstmt.setInt(2, 15000);
      pstmt.setString(3, "Mumbai");

      int num = pstmt.executeUpdate();
      System.out.println("Rows inserted ....");
   }
}
登入後複製

輸出

Connection established......
Number of rows inserted: 1
登入後複製

如果驗證資料庫,您可以觀察表中插入的值:

+---------+--------+----------------+
| Name    | Salary | Location       |
+---------+--------+----------------+
| Amit    | 30000  | Hyderabad      |
| Kalyan  | 40000  | Vishakhapatnam |
| Renuka  | 50000  | Delhi          |
| Archana | 15000  | Mumbai         |
+---------+--------+----------------+
5 rows in set (0.00 sec)
登入後複製

以上是JDBC中的PreparedStatement是什麼?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:tutorialspoint.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!