PreparedStatement介面擴充了Statement接口,它代表一個可以執行多次的預編譯SQL語句。它接受參數化 SQL 查詢,並且您可以向此查詢傳遞 0 個或多個參數。
最初此語句使用佔位符“?” 而不是參數,稍後您可以傳遞參數使用PreparedStatement 介面的setXXX() 方法動態地實作這些。
您可以建立一個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");
建立PreparedStatement物件後,您可以使用PreparedStatement介面的execute()方法之一來執行它,即execute ()、executeUpdate() 和、executeQuery()。
execute(): strong> 此方法在目前準備好的語句物件中執行普通的靜態 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中文網其他相關文章!