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

sqlcommand執行sql

發布時間: 2023-03-19 21:23:45

1. Asp.net(C#) 獲取 執行sql server 語句/存儲過程後的 多個返回值

如果返回
標量
值的話,例者消如文章的個數,可以使用儲存過程的輸出(OUTPUT)參數。在定義存儲過過程時為參數指定OUTPUT關鍵字。C#調用
存儲過程
時指定參數
SqlParameter
對象的
Direction
屬性吵鬧為Output。
如果是返回多個
結果集
的話,可以直接在存儲過程中使用多升嫌罩個select查詢就行。在C#代碼中使用SqlDataReader對象的NextResult方法提取下一個結果集。

2. sqlcommand怎麼樣執行多條sql語句

多個語句寫在一起,每條之間用「;」隔開就行了啊
一次就全部執行了啊

3. 執行SQl語句之後把結果賦給一個變數怎麼寫

你這個問題
要看你是要把喚簡這個結果賦值給那個域內的整形變數了
如果是直接賦值給SQL語句內的一個變數
那麼就像上面的回答一樣
如果是賦值給你程序內的變數
那麼可以使用多個方法,現假定你使用C#:
1.使用一個SqlCommand執行命令
並且得到一個SqlDataReader
然後通過SqlDataReader獲得變數
對應SQL語句:
SELECT
Grade
from
mstSalaryGrade
where
EmployeeManagementID
in(SELECT
EmployeeManagementID
from
mstEmployeeBasic
where
EmployeeCode=26
2.還是使用一個SqlCommand執行存儲過程或語句
不過Grade作為一個輸出參數傳回來
再進行獲取州埋
:
exec
sp_execute
'SELECT
@Grade=Grade
from
mstSalaryGrade
where
EmployeeManagementID
in(SELECT
EmployeeManagementID
from
mstEmployeeBasic
where
EmployeeCode=26',N'@Grade
int
output',0
3.使用SqlCommand執行存儲過程
Grade作為返回值冊鏈螞傳遞回來
:
declare
@Grade
int
SELECT
@Grade
=Grade
from
mstSalaryGrade
where
EmployeeManagementID
in(SELECT
EmployeeManagementID
from
mstEmployeeBasic
where
EmployeeCode=26
return
Grade;

4. 關於Sqlcommand

設置一下cmd的命令類型,
在178行後加:
cdm.commandtype=text;

5. Winform中執行SQL語句的參數問題

你是怎激祥么執行sql語句的 是像下面這樣嗎?還有就是你的sql語句明滾搏是怎麼構造的?能貼出備者來看看么?
public static int ExecuteCommand(string safeSql, params SqlParameter[] values)
{
try
{
SqlConnection conn = new SqlConnection();
conn.ConnectionString = @"your connection string";
using (SqlCommand cmd = new SqlCommand(safeSql, conn))
{
conn.Open();
cmd.Parameters.AddRange(values);
int count = cmd.ExecuteNonQuery();
conn.Close();
return count;
}
}
catch (SqlException ex)
{
throw ex;
}
}

6. 如何用sqlcommand執行sql腳本

string sConnectionString = @"蠢尺server=(local)\SQLEXPRESS;database=Forum;Trusted_Connection=True";

using (SqlConnection conn = new SqlConnection(sConnectionString))

{

conn.Open();

using (SqlCommand cmd = new SqlCommand())

{

// 綁定有效的資料庫連接

cmd.Connection = conn;

// 定義操作1的SQL語句

cmd.CommandText = "Insert into tbClass (ClassName) values ('網頁設計')";

// 完成操作1並輸出相應的記錄數

Response.Write(string.Format("在tbClass中插入了{0}條記錄<br>", cmd.ExecuteNonQuery()));

// 定義操作2的SQL語句

cmd.CommandText = "Select ClassID from tbClass where ClassName='網頁設計'";

// 完成操作2

string sClassID = cmd.ExecuteScalar().ToString();

// 輸出操作2的結果

Response.Write(string.Format("ClassID為{0}<br>", sClassID));

// 定義操作3的SQL語句

cmd.CommandText = string.Format("Insert into tbBoard (BoardName,BoardClassID) values ('PHOTOSHOP','{0}');Insert into tbBoard (BoardName,BoardClassID) values ('FIREWORKS','{0}')", sClassID);

// 完成操作3並輸出相應的記錄數

Response.Write(string.Format("在tbBoard中插入仿檔稿了{0}條記錄<br>", cmd.ExecuteNonQuery()));

// 定義操作4的SQL語句

cmd.CommandText = "Update tbBoard set BoardName='PS技術' where BoardName='PHOTOSHOP'";

// 完成操作4並輸出相應的記錄數

Response.Write(string.Format("在備孝tbBoard中修改了{0}條記錄<br>", cmd.ExecuteNonQuery()));

// 定義操作5的SQL語句

cmd.CommandText = string.Format("Delete from tbBoard where BoardClassID='{0}'", sClassID);

// 完成操作5並輸出相應的記錄數

Response.Write(string.Format("在tbBoard中刪除了{0}條記錄<br>", cmd.ExecuteNonQuery()));

// 定義操作6的SQL語句

cmd.CommandText = string.Format("Delete from tbClass where ClassID='{0}'", sClassID);

// 完成操作6並輸出相應的記錄數

Response.Write(string.Format("在tbClass中刪除了{0}條記錄<br>", cmd.ExecuteNonQuery()));

}

}

7. C#執行sql語句的問題(或者說C#讓SQL語句換行)。

換行是可以,但是你還是不能用GO
SqlCommand發出的語句是一次性執行完的,不允許使用GO
所以你需要把你的SQL語句分解開,多次執行

8. SQL命令怎麼用

SQL語句:

通過SQL語句可以完成對資料庫、表、數據的操作,也就是我們本教程要學習的主要內容。

一條SQL語句類似這樣,它的含義是:從Users表中取出列名為UserName的數據。

一些重要的SQL命令:

  • SELECT – 從資料庫中提取數據

  • UPDATE – 更新資料庫中的數據

  • DELETE – 從資料庫中刪除數據

  • INSERT INTO – 向資料庫中插入新數據

  • CREATE DATABASE – 創建新資料庫

  • ALTER DATABASE – 修改資料庫

  • CREATE TABLE – 創建新表

  • ALTER TABLE – 變更資料庫表

  • DROP TABLE – 刪除表

  • CREATE INDEX – 創建索引

  • DROP INDEX – 刪除索引

-from shulanxt

9. 寫出使用SqlCommand與SqlConnection向資料庫執行一個名為Sql1的SQL查詢

oracle 10g的DBMS_XPLAN包中display_cursor函數不同於display函數,display_cursor用於顯示SQL語句的真實的執行計劃,在大多數情況下,
顯示真實的執行計劃有助於更好的分析SQL語句的全過程,尤其是運行此SQL語句實時的I/O開銷。通過對比預估的I/O與真實的I/O開銷來判斷
SQL語句所存在問題,如缺少統計信息,SQL語句執行的次數,根據搏旁實際中間結果集的大小來選擇合適的連接方式等。本文僅僅講述
display_cursor函數的使用。

一、display_cursor函數用法
1、display_cursor函數語法

DBMS_XPLAN.DISPLAY_CURSOR(
sql_id IN VARCHAR2 DEFAULT NULL,
cursor_child_no IN NUMBER DEFAULT NULL,
format IN VARCHAR2 DEFAULT 'TYPICAL');

2、display_cursor函數參數描述
sql_id
指定位於庫基緩橡緩存執行計劃中SQL語句的父游標。默認值為null。當使用默認值時當前會話的最後一條SQL語句的執行計劃將被返回
可以通過查詢V$SQL 或V$SQLAREA的SQL_ID列來獲得SQL語句的SQL_ID。
cursor_child_no
指定父游標下子游標的序號。即指定被返回執行計劃的SQL語句的子游標。默認值為0。如果為null,則sql_id所指父游標下所有子游標
的執行計劃都將被返回。
format
控制SQL語句執行計劃的輸出部分,即哪些可以顯示哪些不顯示。使用與display函哪賀數的format參數與修飾符在這里同樣適用。
除此之外當在開啟statistics_level=all時或使用gather_plan_statistics提示可以獲得執行計劃中實時的統計信息
有關詳細的format格式描述請參考:dbms_xplan之display函數的使用 中format參數的描述

下面給出啟用統計信息時format新增的修飾符
iostats 控制I/O統計的顯示
last 默認,顯示所有執行計算過的統計。如果指定該值,則只顯示最後一次執行的統計信息
memstats 控制pga相關統計的顯示
allstats 此為iostats memstats的快捷方式,即allstats包含了iostats和memstats
run_stats_last 等同於iostats last。只能用於oracle 10g R1
run_stats_tot 等同於iostats。只能用於oracle 10g R1

抓一個最近一小時最消耗IO的SQL:
SELECT sql_id, COUNT(*)
FROM gv$active_session_history ash, gv$event_name evt
WHERE ash.sample_time > SYSDATE - 1 / 24
AND ash.session_state = 'WAITING'
AND ash.event_id = evt.event_id
AND evt.wait_class = 'User I/O'
GROUP BY sql_id
ORDER BY COUNT(*) DESC;

執行上面的SQL:
SQL> SELECT sql_id, COUNT(*)
FROM gv$active_session_history ash, gv$event_name evt
2 3 WHERE ash.sample_time > SYSDATE - 1 / 24
4 AND ash.session_state = 'WAITING'
5 AND ash.event_id = evt.event_id
6 AND evt.wait_class = 'User I/O'
7 GROUP BY sql_id
8 ORDER BY COUNT(*) DESC;

SQL_ID COUNT(*)
------------- ----------
g7fu6qba82m6b 668
63r47zyphdk06 526
9f5m4wd88nc1h 514
593p47drw5fhk 232
br91w16jzy4fu 120
4fvwyjpnh6tp7 78
gm0nrbfuj8kzr 70
2184k363hw4xd 68
gc4dajs7g5myy 46
8vrk9sfuwfdgq 42
ccpnb4dwdmq21 40

查看SQL的執行計劃:
SELECT * FROM TABLE(dbms_xplan.display_cursor('g7fu6qba82m6b'));

在SQLPLUS中執行:
SQL> set pagesize 2000
SQL> SELECT * FROM TABLE(dbms_xplan.display_cursor('g7fu6qba82m6b'));

PLAN_TABLE_OUTPUT
------------------------------------------------------------------------------------------------------------------------
SQL_ID g7fu6qba82m6b, child number 0
-------------------------------------
UPDATE "CPDDS_PDATA"."CDM_LEDGER" SET "CSTM_NAME" = :a1,"CSTM_NO" =
:a2,"PAPER_TYPE" = :a3,"PAPER_NO" = :a4,"CURR_TYPE" = :a5,"SVT_NO" =
:a6,"BAL_DIR" = :a7,"BAL" = :a8,"AVAL_BAL" = :a9,"NORM_FRATIO" =
:a10,"PK_BAL" = :a11,"DR_ACCU" = :a12,"CR_ACCU" = :a13,"LAST_TRAN_DATE" =
:a14,"LAST_TRAN_TIME" = :a15,"PRT_LINE_NUM" = :a16,"NOREG_PK_REC_NUM" =
:a17,"PK_NO" = :a18,"PWD" = :a19,"FLAG" = :a20,"FRZ_FLAG" =
:a21,"CARD_HOLD_FLAG" = :a22,"PK_HOLD_FLAG" = :a23,"BGN_INT_DATE" =
:a24,"OPEN_DATE" = :a25,"ACC_HOLD_FLAG" = :a26,"CLS_DATE" =
:a27,"OPEN_TLR" = :a28,"CLS_TLR" = :a29,"CLS_INT" = :a30,"OPEN_INST" =
:a31,"ADD_NUM" = :a32,"DAC" = :a33,"FRZ_TIMES1" = :a34,"FRZ_TIMES2" =
:a35,"HOST_SEQNO" = :a36,"D_UPDATE_DATE" = :a37 WHERE "ACC" = :b0

Plan hash value: 319441092

-----------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
-----------------------------------------------------------------------------------
| 0 | UPDATE STATEMENT | | | | 3 (100)| |
| 1 | UPDATE | CDM_LEDGER | | | | |
|* 2 | INDEX UNIQUE SCAN| I_CDM_LEDGER | 1 | 269 | 2 (0)| 00:00:01 |
-----------------------------------------------------------------------------------

Predicate Information (identified by operation id):
---------------------------------------------------

2 - access("ACC"=:B0)

29 rows selected.

總結
1、與display函數不同,display_cursor顯示的為真實的執行計劃
2、對於format參數,使用與display函數的各個值,同樣適用於display_cursor函數
3、當statistics_level為all或使用gather_plan_statistics提示可以獲得執行時的統計信息
4、根據真實與預估的統計信息可以初步判斷SQL效率低下的原因,如統計信息的准確性、主要的開銷位於那些步驟等

10. 如何在mysql shell命令中執行sql命令行

本文介紹 MySQL 8.0 shell 子模塊 Util 的兩個導入特性 importTable/import_table(JS和python 版本的命名差異)、importJson/import_json的使用方法。


其中 import_table 是通過傳統 MySQL 協議來通信,Import_json 是通過 X 插件協議來通信。MySQL 一直以來提供導入文件 SQL 命令 load data infile(單線程)以及對應的可執行文件 mysqlimport(多線程)。


比如我導入 100W 行示例數據到表 ytt.tl1,花了 24 秒。這個已經是 MySQL 默認導入來的最快的。分析那我們現在看下 mysqlimport 工具的升級版,mysqlshell 的 util 工具集。


使用這兩個工具之前,必須得臨時開啟 local_infile 選項。1. import_table建立 3306 埠的新連接我這里切換為 python 模式清空掉示例表 Ytt.tl1import_table 有兩個參數,第一個參數定義導入文件的路徑,第二個定義相關選項,比如導入的格式,並發的數量等。定義文件路徑(參數1)定義選項(參數2)執行導入:只花了不到 17 秒,比傳統 mysqlimport 快了不少。


我們上面指定了顯式指定了欄位分隔符,那有沒有已經定義好的組合格式呢? 答案是有的,選項 dialect 可以指定以下格式:csv,tsv,json,csv-unix那麼上面的導入,我們可以更簡單,改下變數 y_options1 的定義導入時間差不多。這里要說明下,dialect 選項的優先順序比較低,比如添加了'linesTerminatedBy':' ', 則覆蓋他自己的' '。


選項 diaelect 還有一個可選值為 json,可以直接把 json 結果導入到文檔表裡。比如我新建一張表 tl1_json重新定義文件以及導入選項。導入 JSON 數據速度也還可以,不到 24 秒。那導入 json 數據,就必須得提到以 X 插件協議通信的工具 import_json了。2. imort_json我們切換到 mysqlx 埠import_json 參數和 Import_table 參數類似,這里我改下選項我在手冊上沒有看到多線程的選項,所以單線程跑 35 秒慢了些。查看剛剛導入的數據import_json 不僅僅可以導入 Json 數據,更重要的是可以在 BSON 和 JSON 之間平滑的轉換,有興趣的同學可以去 TRY 下。