當前位置:首頁 » 編程語言 » sql里execute
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

sql里execute

發布時間: 2022-09-11 19:32:36

sql中execute,executequery和executeupdate之間的區別

JDBCTM中Statement介面提供的execute、executeQuery和executeUpdate之間的區別
Statement
介面提供了三種執行
SQL
語句的方法:executeQuery、executeUpdate和
execute。使用哪一個方法由
SQL
語句所產生的內容決定。
方法executeQuery
用於產生單個結果集的語句,例如
SELECT
語句。
被使用最多的執行
SQL
語句的方法是
executeQuery。這個方法被用來執行
SELECT
語句,它幾乎是使用最多的
SQL
語句。
方法executeUpdate
用於執行
INSERT、UPDATE

DELETE
語句以及
SQL
DDL(數據定義語言)語句,例如
CREATE
TABLE

DROP
TABLE。INSERT、UPDATE

DELETE
語句的效果是修改表中零行或多行中的一列或多列。executeUpdate
的返回值是一個整數,指示受影響的行數(即更新計數)。對於
CREATE
TABLE

DROP
TABLE
等不操作行的語句,executeUpdate
的返回值總為零。
使用executeUpdate方法是因為在
createTableCoffees
中的
SQL
語句是
DDL
(數據定義語言)語句。創建表,改變表,刪除表都是
DDL
語句的例子,要用
executeUpdate
方法來執行。你也可以從它的名字里看出,方法
executeUpdate
也被用於執行更新表
SQL
語句。實際上,相對於創建表來說,executeUpdate
更多時間是用於更新表,因為表只需要創建一次,但經常被更新。
方法execute:
用於執行返回多個結果集、多個更新計數或二者組合的語句。因為多數程序員不會需要該高級功能
execute方法應該僅在語句能返回多個ResultSet對象、多個更新計數或ResultSet對象與更新計數的組合時使用。當執行某個已存儲過程
或動態執行未知
SQL
字元串(即應用程序程序員在編譯時未知)時,有可能出現多個結果的情況,盡管這種情況很少見。
因為方法
execute
處理非常規情況,所以獲取其結果需要一些特殊處理並不足為怪。例如,假定已知某個過程返回兩個結果集,則在使用方法
execute
執行該過程後,必須調用方法
getResultSet
獲得第一個結果集,然後調用適當的
getXXX
方法獲取其中的值。要獲得第二個結果集,需要先調用
getMoreResults
方法,然後再調用
getResultSet
方法。如果已知某個過程返回兩個更新計數,則首先調用方法
getUpdateCount,然後調用
getMoreResults,並再次調用
getUpdateCount。
對於不知道返回內容,則情況更為復雜。如果結果是
ResultSet
對象,則方法
execute
返回
true;如果結果是
Java
int,則返回
false。如果返回
int,則意味著結果是更新計數或執行的語句是
DDL
命令。在調用方法
execute
之後要做的第一件事情是調用
getResultSet

getUpdateCount。調用方法
getResultSet
可以獲得兩個或多個
ResultSet
對象中第一個對象;或調用方法
getUpdateCount
可以獲得兩個或多個更新計數中第一個更新計數的內容。

Ⅱ sql語句 execute,executeQuery和executeUpdate之間的區別

Statement 介面提供了三種執行 SQL 語句的方法:executeQuery、executeUpdate 和 execute。使用哪一個方法由 SQL 語句所產生的內容決定。

方法executeQuery

用於產生單個結果集的語句,例如 SELECT 語句。 被使用最多的執行 SQL 語句的方法是 executeQuery。這個方法被用來執行 SELECT 語句,它幾乎是使用最多的 SQL 語句。

方法executeUpdate

用於執行 INSERT、UPDATE 或 DELETE 語句以及 SQL DDL(數據定義語言)語句,例如 CREATE TABLE 和 DROP TABLE。INSERT、UPDATE 或 DELETE 語句的效果是修改表中零行或多行中的一列或多列。executeUpdate 的返回值是一個整數,指示受影響的行數(即更新計數)。對於 CREATE TABLE 或 DROP TABLE 等不操作行的語句,executeUpdate 的返回值總為零。

使用executeUpdate方法是因為在 createTableCoffees 中的 SQL 語句是 DDL (數據定義語言)語句。創建表,改變表,刪除表都是 DDL 語句的例子,要用 executeUpdate 方法來執行。你也可以從它的名字里看出,方法 executeUpdate 也被用於執行更新表 SQL 語句。實際上,相對於創建表來說,executeUpdate 用於更新表的時間更多,因為表只需要創建一次,但經常被更新。

方法execute:

用於執行返回多個結果集、多個更新計數或二者組合的語句。因為多數程序員不會需要該高級功能

execute方法應該僅在語句能返回多個ResultSet對象、多個更新計數或ResultSet對象與更新計數的組合時使用。當執行某個已存儲過程 或動態執行未知 SQL 字元串(即應用程序程序員在編譯時未知)時,有可能出現多個結果的情況,盡管這種情況很少見。
因為方法 execute 處理非常規情況,所以獲取其結果需要一些特殊處理並不足為怪。例如,假定已知某個過程返回兩個結果集,則在使用方法 execute 執行該過程後,必須調用方法 getResultSet 獲得第一個結果集,然後調用適當的 getXXX 方法獲取其中的值。要獲得第二個結果集,需要先調用 getMoreResults 方法,然後再調用 getResultSet 方法。如果已知某個過程返回兩個更新計數,則首先調用方法 getUpdateCount,然後調用 getMoreResults,並再次調用 getUpdateCount。
對於不知道返回內容,則情況更為復雜。如果結果是 ResultSet 對象,則方法 execute 返回 true;如果結果是 Java int,則返回 false。如果返回 int,則意味著結果是更新計數或執行的語句是 DDL 命令。在調用方法 execute 之後要做的第一件事情是調用 getResultSet 或 getUpdateCount。調用方法 getResultSet 可以獲得兩個或多個 ResultSet 對象中第一個對象;或調用方法 getUpdateCount 可以獲得兩個或多個更新計數中第一個更新計數的內容。
當 SQL 語句的結果不是結果集時,則方法 getResultSet 將返回 null。這可能意味著結果是一個更新計數或沒有其它結果。在這種情況下,判斷 null 真正含義的唯一方法是調用方法 getUpdateCount,它將返回一個整數。這個整數為調用語句所影響的行數;如果為 -1 則表示結果是結果集或沒有結果。如果方法 getResultSet 已返回 null(表示結果不是 ResultSet 對象),則返回值 -1 表示沒有其它結果。也就是說,當下列條件為真時表示沒有結果(或沒有其它結果):

((stmt.getResultSet() == null) && (stmt.getUpdateCount() == -1))

如果已經調用方法 getResultSet 並處理了它返回的 ResultSet 對象,則有必要調用方法 getMoreResults 以確定是否有其它結果集或更新計數。如果 getMoreResults 返回 true,則需要再次調用 getResultSet 來檢索下一個結果集。如上所述,如果 getResultSet 返回 null,則需要調用 getUpdateCount 來檢查 null 是表示結果為更新計數還是表示沒有其它結果。

當 getMoreResults 返回 false 時,它表示該 SQL 語句返回一個更新計數或沒有其它結果。因此需要調用方法 getUpdateCount 來檢查它是哪一種情況。在這種情況下,當下列條件為真時表示沒有其它結果:

((stmt.getMoreResults() == false) && (stmt.getUpdateCount() == -1))

Ⅲ sql語句 execute,executeQuery和executeUpdate之間的區別

PreparedStatement介面提供了三種執行 SQL 語句的方法:executeQuery、executeUpdate 和 execute。使用哪一個方法由 SQL 語句所產生的內容決定。
1、方法executeQuery
用於產生單個結果集的語句,例如 SELECT 語句。 被使用最多的執行 SQL 語句的方法是 executeQuery。這個方法被用來執行 SELECT 語句,它幾乎是使用最多的 SQL 語句。
2、方法executeUpdate
用於執行 INSERT、UPDATE 或 DELETE 語句以及 SQL DDL(數據定義語言)語句,例如 CREATE TABLE 和 DROP TABLE。INSERT、UPDATE 或 DELETE 語句的效果是修改表中零行或多行中的一列或多列。executeUpdate 的返回值是一個整數,指示受影響的行數(即更新計數)。對於 CREATE TABLE 或 DROP TABLE 等不操作行的語句,executeUpdate 的返回值總為零。
使用executeUpdate方法是因為在 createTableCoffees 中的 SQL 語句是 DDL (數據定義語言)語句。創建表,改變表,刪除表都是 DDL 語句的例子,要用 executeUpdate 方法來執行。你也可以從它的名字里看出,方法 executeUpdate 也被用於執行更新表 SQL 語句。實際上,相對於創建表來說,executeUpdate 用於更新表的時間更多,因為表只需要創建一次,但經常被更新。

Ⅳ SQL語句execute後的參數拜託了各位 謝謝

2.CONN.EXECUTE(SQL,RowsAffected,C) 參數含義:SQL的值可以是SQL語句、表名、存儲過程名,也可以是數據提供者所能接受的任意字元串。為了提高性能,最好為C參數指定合適的值可選參數RowsAffected將返回INSERT、UPDATE或DELETE查詢執行以後所影響的數目。這些查詢會返回一個關閉的Recordset對象。一個SELECT查詢將返回RowsAffected值為-1並且返回帶有一行或多行內容的打開的Recordset

麻煩採納,謝謝!

Ⅳ sql語句 execute,executeQuery和executeUpdate之間的區別

execute、executeQuery和executeUpdate之間的區別
JDBC中Statement 介面提供了三種執行 SQL 語句的方法:executeQuery、executeUpdate 和 execute。使用哪一個方法由 SQL 語句所產生的內容決定。
1>方法executeQuery
用於產生單個結果集(ResultSet)的語句,例如 SELECT 語句。 被使用最多的執行 SQL 語句的方法。這個方法被用來執行 SELECT 語句,它幾乎是使用最多的 SQL 語句。但也只能執行查詢語句,執行後返回代表查詢結果的ResultSet對象。
如:
//載入資料庫驅動
Class.forName("com.mysql.jdbc.Driver");
//使用DriverManager獲取資料庫連接
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test",
"root","1234");
//使用Connection來創建一個Statment對象
Statement stmt = conn.createStatement();
//執行查詢語句
ResultSet rs =stmt.executeQuery("select * from teacher");
//把查詢結果輸出來
while (rs.next())
{
System.out.println(rs.getInt(1) + "/t" + rs.getString(2));
}
2>方法executeUpdate
用於執行 INSERT、UPDATE 或 DELETE 語句以及 SQL DDL(數據定義語言)語句,例如 CREATE TABLE 和 DROP TABLE。INSERT、UPDATE 或 DELETE 語句的效果是修改表中零行或多行中的一列或多列。executeUpdate 的返回值是一個整數(int),指示受影響的行數(即更新計數)。對於 CREATE TABLE 或 DROP TABLE 等不操作行的語句,executeUpdate 的返回值總為零。
如:
//載入資料庫驅動
Class.forName("com.mysql.jdbc.Driver");
//使用DriverManager獲取資料庫連接
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test",
"root","1234");
//使用Connection來創建一個Statment對象
Statement stmt = conn.createStatement();
//執行DML語句,返回受影響的記錄條數
return stmt.executeUpdate(sql);
3>方法execute:
可用於執行任何SQL語句,返回一個boolean值,表明執行該SQL語句是否返回了ResultSet。如果執行後第一個結果是ResultSet,則返回true,否則返回false。但它執行SQL語句時比較麻煩,通常我們沒有必要使用execute方法來執行SQL語句,而是使用executeQuery或executeUpdate更適合,但如果在不清楚SQL語句的類型時則只能使用execute方法來執行該SQL語句了。
如: //載入驅動
Class.forName(driver);
//獲取資料庫連接
conn = DriverManager.getConnection(url , user , pass);
//使用Connection來創建一個Statment對象
stmt = conn.createStatement();
//執行SQL,返回boolean值表示是否包含ResultSet
boolean hasResultSet = stmt.execute(sql);
//如果執行後有ResultSet結果集
if (hasResultSet)
{
//獲取結果集
rs = stmt.getResultSet();
//ResultSetMetaData是用於分析結果集的元數據介面
ResultSetMetaData rsmd = rs.getMetaData();
int columnCount = rsmd.getColumnCount();
//迭代輸出ResultSet對象
while (rs.next())
{//依次輸出每列的值
for (int i = 0 ; i < columnCount ; i++ )
{
System.out.print(rs.getString(i + 1) + "/t");
}
System.out.print("/n");
}
}
else
{
System.out.println("該SQL語句影響的記錄有" + stmt.getUpdateCount() + "條");
}

Ⅵ 請幫我看看這段sql里 execute的用法

TESTDB_ChkID應該是個自定義函數,你到SqlServer伺服器的可編程性-函數-標量值函數里找找,@R是這個函數的返回值,後面4個@IDNO = N'666#-333'
,@ADD1 = N'1-ETSF'
,@ADD2 = N'1-CDEN'
,@UPDATEFLG = 0
是函數執行時傳入的參數。

Ⅶ SQL語句execute後的參數

2.CONN.EXECUTE(SQL,RowsAffected,C)

參數含義:SQL的值可以是SQL語句、表名、存儲過程名,也可以是數據提供者所能接受的任意字元串。為了提高性能,最好為C參數指定合適的值可選參數RowsAffected將返回INSERT、UPDATE或DELETE查詢執行以後所影響的數目。這些查詢會返回一個關閉的Recordset對象。一個SELECT查詢將返回RowsAffected值為-1並且返回帶有一行或多行內容的打開的Recordset

Ⅷ sql中execute,executequery和executeupdate之間的區別

在用純JSP做一個頁面報警功能的時候習慣性的用executeQuery來執行SQL語句,結果執行update時就遇到問題,語句能執行,但返回結果
出現問題,另外還忽略了executeUpdate的返回值不是結果集ResultSet,而是數值!特收藏如下一篇文章(感謝網友們對各種信息的貢
獻):

JDBCTM中Statement介面提供的execute、executeQuery和executeUpdate之間的區別

Statement 介面提供了三種執行 SQL 語句的方法:executeQuery、executeUpdate 和 execute。使用哪一個方法由 SQL 語句所產生的內容決定。

方法executeQuery
用於產生單個結果集的語句,例如 SELECT 語句。 被使用最多的執行 SQL 語句的方法是 executeQuery。這個方法被用來執行 SELECT 語句,它幾乎是使用最多的 SQL 語句。

方法executeUpdate

於執行 INSERT、UPDATE 或 DELETE 語句以及 SQL DDL(數據定義語言)語句,例如 CREATE TABLE 和 DROP
TABLE。INSERT、UPDATE 或 DELETE 語句的效果是修改表中零行或多行中的一列或多列。executeUpdate
的返回值是一個整數,指示受影響的行數(即更新計數)。對於 CREATE TABLE 或 DROP TABLE
等不操作行的語句,executeUpdate 的返回值總為零。

使用executeUpdate方法是因為在
createTableCoffees 中的 SQL 語句是 DDL (數據定義語言)語句。創建表,改變表,刪除表都是 DDL 語句的例子,要用
executeUpdate 方法來執行。你也可以從它的名字里看出,方法 executeUpdate 也被用於執行更新表 SQL
語句。實際上,相對於創建表來說,executeUpdate 用於更新表的時間更多,因為表只需要創建一次,但經常被更新。

方法execute:
用於執行返回多個結果集、多個更新計數或二者組合的語句。因為多數程序員不會需要該高級功能

execute方法應該僅在語句能返回多個ResultSet對象、多個更新計數或ResultSet對象與更新計數的組合時使用。當執行某個已存儲過程或動態執行未知 SQL 字元串(即應用程序程序員在編譯時未知)時,有可能出現多個結果的情況,盡管這種情況很少見。

為方法 execute 處理非常規情況,所以獲取其結果需要一些特殊處理並不足為怪。例如,假定已知某個過程返回兩個結果集,則在使用方法
execute 執行該過程後,必須調用方法 getResultSet 獲得第一個結果集,然後調用適當的 getXXX
方法獲取其中的值。要獲得第二個結果集,需要先調用 getMoreResults 方法,然後再調用 getResultSet
方法。如果已知某個過程返回兩個更新計數,則首先調用方法 getUpdateCount,然後調用 getMoreResults,並再次調用
getUpdateCount。
對於不知道返回內容,則情況更為復雜。如果結果是 ResultSet 對象,則方法 execute 返回
true;如果結果是 Java int,則返回 false。如果返回 int,則意味著結果是更新計數或執行的語句是 DDL 命令。在調用方法
execute 之後要做的第一件事情是調用 getResultSet 或 getUpdateCount。調用方法 getResultSet
可以獲得兩個或多個 ResultSet 對象中第一個對象;或調用方法 getUpdateCount
可以獲得兩個或多個更新計數中第一個更新計數的內容。
當 SQL 語句的結果不是結果集時,則方法 getResultSet 將返回
null。這可能意味著結果是一個更新計數或沒有其它結果。在這種情況下,判斷 null 真正含義的唯一方法是調用方法
getUpdateCount,它將返回一個整數。這個整數為調用語句所影響的行數;如果為 -1 則表示結果是結果集或沒有結果。如果方法
getResultSet 已返回 null(表示結果不是 ResultSet 對象),則返回值 -1
表示沒有其它結果。也就是說,當下列條件為真時表示沒有結果(或沒有其它結果):

((stmt.getResultSet() == null) && (stmt.getUpdateCount() == -1))


果已經調用方法 getResultSet 並處理了它返回的 ResultSet 對象,則有必要調用方法 getMoreResults
以確定是否有其它結果集或更新計數。如果 getMoreResults 返回 true,則需要再次調用 getResultSet
來檢索下一個結果集。如上所述,如果 getResultSet 返回 null,則需要調用 getUpdateCount 來檢查 null
是表示結果為更新計數還是表示沒有其它結果。

當 getMoreResults 返回 false 時,它表示該 SQL 語句返回一個更新計數或沒有其它結果。因此需要調用方法 getUpdateCount 來檢查它是哪一種情況。在這種情況下,當下列條件為真時表示沒有其它結果:

((stmt.getMoreResults() == false) && (stmt.getUpdateCount() == -1))

下面的代碼演示了一種方法用來確認已訪問調用方法 execute 所產生的全部結果集和更新計數:

stmt.execute(queryStringWithUnknownRe
sults);
while (true) {
int rowCount = stmt.getUpdateCount();
if (rowCount > 0) { // 它是更新計數
System.out.println("Rows changed = " + count);
stmt.getMoreResults();
continue;
}
if (rowCount == 0) { // DDL 命令或 0 個更新
System.out.println(" No rows changed or statement was DDL
command");
stmt.getMoreResults();
continue;
}

// 執行到這里,證明有一個結果集
// 或沒有其它結果

ResultSet rs = stmt.getResultSet;
if (rs != null) {
. . . // 使用元數據獲得關於結果集列的信息
while (rs.next()) {
. . . // 處理結果
stmt.getMoreResults();
continue;
}

Ⅸ SQL中EXECUTE許可權的作用

提供執行特定的存儲過程或用戶自定義函數的能力。

Ⅹ execute函數的用法

tempcon是個ADO用來連接資料庫的智能指針,Execute方法用來執行sql語句。如果這條語句有數據返回,比如select。那麼返回結果就給了temprecord。

輸入值的集合X被稱為f的定義域;可能的輸出值的集合Y被稱為f的值域。函數的值域是指定義域中全部元素通過映射f得到的實際輸出值的集合。注意,把對應域稱作值域是不正確的,函數的值域是函數的對應域的子集。

計算機科學中,參數和返回值的數據類型分別確定了子程序的定義域和對應域。因此定義域和對應域是函數一開始就確定的強制進行約束。另一方面,值域是和實際的實現有關。

函數與不等式和方程存在聯系(初等函數)。令函數值等於零,從幾何角度看,對應的自變數的值就是圖像與X軸的交點的橫坐標。

從代數角度看,對應的自變數是方程的解。另外,把函數的表達式(無表達式的函數除外)中的「=」換成「<」或「>」,再把「Y」換成其它代數式,函數就變成了不等式,可以求自變數的范圍。