搜尋
首頁後端開發C#.Net教程ADO.NET呼叫預存程序

ADO.NET呼叫預存程序

Dec 20, 2016 pm 05:05 PM
.net

一: 執行不帶回傳參數(Input)的預存程序
1: 首先在資料庫寫個預存程序, 如建立個 addUser預存程序。
Create Proc addUser
@ID int,
@Name varchar(20),
@Sex varchar(20)
As
Insert Into Users Values( @ID, @Name,@Sex )

Insert Into Users Values( @ID, @Name,@Sex )

Insert Into Users Values( @ID, @Name,@Sex )
Insert Into Users Values( @ID, @Name,@Sex )
且初始SqlCommand物件如:
SqlCommand cmd = new SqlCommand( );
cmd.CommandText = "addUser"; //制定呼叫哪個預存程序
cmd.CommandType = CommandType.StoredProcedure; // 制定Sql指令類型是儲存過程,預設的為Sql語句。

cmd.Connection = con; // 設定連線


3:新增預存程序參數至SqlCommand物件
SqlParameter param = new SqlParameter( ); //定義一個參數物件
param.ParameterName = "@ID"; //預存程序參數名稱
param.Value = txtID.Text.Trim(); // 此參數的值

cmd.Parameters.Add( param ); // SqlCommand物件新增此參數物件


param = new SqlParameter( "@ Name", txtName.Text.Trim() ); // 簡寫方式

cmd.Parameters.Add( param );


4:SqlCommand物件呼叫執行Sql的函數。如:
cmd.ExecuteNonQuery();

二:執行帶有回傳參數(Output)的預存程序
1: 首先在資料庫寫入預存程序, 如建立個 queryUser預存程序。
alter Proc queryUser
@ID int,
@Suc varchar(10)
2:建立SqlCommand對象,並初始SqlCommand物件如:
SqlCommand cmd = new SqlCommand( );
cmd.CommandText = "queryUser"; //制定呼叫哪個儲存程序

cmd.CommandType = CommandType.StoredProcedure; Sql指令類型是預存過程, 預設的為Sql語句。

cmd.Connection = con; // 設定連接

3:向SqlCommand物件新增預存程序參數
SqlParameter param1 = new SqlParameter( "@ID", txtID.Text ); // 新增輸入參數
cmd.Parameters. Add( param1 );

SqlParameter param2 = new SqlParameter(); // 新增輸出參數
param2.ParameterName = "@Suc"; // 名稱
param2.SqlDbType = SqlDbType. SqlDbType.Sarcc param2.Size = 10;// 輸出參數的Sql型別

param2.Direction = ParameterDirection.Output; //指定此參數物件為輸出參數型別

cmd.Parameters.Add( param2 );

4:SqlCommand,4:SqlCommand執行Sql的函數。如:
cmd.ExecuteNonQuery();
MessageBox.Show( param2.Value.ToString() ); // 輸出輸出參數的值

輸入參數的預存程序的範例:

try
{

輸入參數的儲存過程的範例:

try
{
();
cmd.Connection = con;
cmd.CommandType = CommandType.StoredProcedure;
cmd.CommandText = "addUser";

SqlParameter param = new SqlParameter( );
SqlParameter param = new SqlParameter( );
param."; .Value = txtID.Text.Trim();
cmd.Parameters.Add( param );

param = new SqlParameter( "@Name", txtName.Text.Trim() );

cmd.Parameters.Add( paramters.Add( param). );

param = new SqlParameter();

param.ParameterName = "@Sex";
param.Value = txtSex.Text.Trim();
cmd.Parameters.Add( param );
InsertCommand = cmd;

if ( cmd.ExecuteNonQuery() == 1 )
{
MessageBox.Show( "新增成功" );
}
else
{
MessageBox.Show(");
catch( SqlException ex )
{
MessageBox.Show( ex.Message );
}

輸出參數的預存程序的範例:
try
{

SllCommand cmd = newSft); ";

cmd.CommandType = CommandType.StoredProcedure;
cmd.Connection = con;

SqlParameter param1 = new SqlParameter( "@ID", txtID.Text );
cmd.Parameters.Addsgmparamah = new SqlParameter();
param2.ParameterName = "@Suc";
param2.SqlDbType = SqlDbType.VarChar;
param2.Size = 10;
param2.Direction = parameterDirection. ;

cmd.ExecuteNonQuery();


MessageBox.Show( param1.Value.ToString() );
MessageBox.Show( param2.Value.ToString() );
MessageBox.Show( param2.Value.ToString() );

MessageBox.Show( ex.Message );
}

在ado.net 裡面取得回傳值的方法為(c#):
--------------------- ---------------------------------------
SqlConnection dbconn = new SqlConnection(connStr);

。 .Add("@srcPos",SqlDbType.VarChar);

SqlParameter rtnval = cmd.Parameters.Add("rval",SqlDbType.Int);

tmpName.Direction =InmeterDirection.Int);

tmpName.Direction =InmeterDirection.Inputir.Direction. ;

rtnval.Direction = ParameterDirection.ReturnValue;

tmpName.Value = "";
srcPos.Value = "";
dbconn.Open();
cmd.ExecuteNonQuery();
dbconn.Close();

tmpid = (int)rtnvalid = (int)。此處即為回傳值

假設有預存程序如下:
----------------------------------- ----------

CREATE proc sp_uptmp @tmpName varchar(50),@srcPos varchar(255)
as

Begin TRAN
insert into t_template values(@tmpName,Begin TRAN
insert into t_template values(@tmpName,Begin TRAN

insert into t_? return isnull(@@identity,0)

GO

------------------------------------ ------------------------
在ado.net 裡面取得回傳值的方法為(c#):
--------- -------------------------------------------------- -
SqlConnection dbconn = new SqlConnection(connStr);
SqlCommand cmd = new SqlCommand("sp_uptmp",dbconn);
cmd.CommandType = CommandType.StoredProcedure;Parg SqlDbType.VarChar);
SqlParameter srcPos = _cmd.Parameters.Add("@srcPos",SqlDbType.VarChar);

SqlParameter rtnval = cmTyped.Parameters.Add("rvalueD.DlType; ParameterDirection.Input;

srcPos.Direction = ParameterDirection.Input;
rtnval.Direction = ParameterDirection.ReturnValue;

tmpName.Value = "";

srcPos.

tmpName.Value = "";jdbconnet.m. ();

dbconn.Close();


tmpid = (int)rtnval.Value; //此處即為傳回值

在ADO環境下,呼叫儲存程序查詢資料時常規做法為:
1 建立Connection Command物件

2 開啟連線,給Command賦參數的名稱、資料型別、值

3 執行Command物件

4 傳回給Recordset物件交給客戶端

這樣做每呼叫一次儲存程序都要依照預存程序中的參數的資料型別建立Parameters物件
例如預存程序需要兩個參數@ID int、@Name varchar(10)就需要
'建立參數
cmd.Parameters.Append cmd.CreateParameter("@ID",adInteger,adParamInput,4)
cmd.Parameters.Append cmd.CreateParameter("@Name",adVarChar,adParamInput,10)
'給參數賦值
cmd("@State") = 1
cmd("@WhereT")=”2”
每」2”
呼叫一個預存程序都要手動添加這個預存程序的所有參數,用自己的腦力保證參數的資料類型和預存過程中的參數的資訊的一致性。
Command.Parameters物件有一個Refresh方法,這個方法的作用時讀取目前Command物件所需的所有參數的名稱和資料類型,用這個方法就可以寫成一個呼叫所有儲存過程的共用函數,現面這個函數完成了一個傳回結果集的預存程序的通用函數。很簡單可以根據需要細化。

‘在VisualBasic6.0調試通過。
Function GetRsByPro(strConnString As String, strProName As String, arjParameter() As String)
' 傳回查詢的記錄集

' strConnString 資料連線字串

' strProName 儲存過程名稱
' arjParameter(e) 資料庫編號GoTo errMsg
'建立ADO物件
Dim Cmd As New Command
' ASP Con = Server.CreateObject("ADODB.Connection")
Dim Con As New Connection
' ASP Set Cmd = Server.CreateObject("ADODB.Command")
Dim Rs As New Recordset
' ASP Set rs = Server.CreateObject("ADODB.Recordset")

'開啟資料庫
Con.Open strConnString
Set Cmd.ActiveConnection. Refresh
If UBound(arjParameter) Cmd.Parameters.Count Then
Debug.Print "參數個數不對"
Exit Function
End If

'給預存程序參數賦值
For i = 08C. - 1
Cmd.Parameters(i).Value = arjParameter(i)
Next

'設定Recordset物件
Rs.CursorType = 3
Rs.LockType = 3
Rs.CursorType = 3
Rs.LockType = 3
Rs.CursorType = 3
Rs.LockType = 3
Rs.CursorType = 3
Rs.LockType = 3
Rs.CursorType = 303
. Rs.Open

'返回結果集
Set GetRsByPro = Rs

'關閉資料來源
Con.Close
Set Con = Nothing
errMsg:
Debug.Print Err.Description
Func As New Recordset
StrConnString=””
StrProName=”pro_GetAllUser”

Dim arjParameter(1)

arjParameter(0)=”1”
arjParameter(1)=”山東” ))

用相同的方法在.NET開發環境裡也可以建立一個通用的方法呼叫預存程序。
在ADO.NET裡不管是OleDbCommand.Parameters物件還是SqlCommand.Parameters物件都沒有Refresh方法讀取預存程序的參數信息,.NET在OleDbCommandBuilder類別裡提供了一個DeriveParameters靜態方法可以實現相同的功能。
.NET SDK裡關於DeriveParameters的描述
“使用在 SqlCommand 中指定的存儲過程的參數信息,填充指定的 SqlCommand 對象的 Parameters 集合。”

SqlConnection Conn=new SqlConnection(cnString);
Conn.Open();
SqlCommand Comm=new SqlCommand();
Comm.Connection =conn;
Comm.CommandType =CommandType.StoredProcedure ;
Comm. SqlCommandBuilder.DeriveParameters(comm);
//經過這個方法後SqlCommand物件的SqlParameters物件已經幫定了儲存過程中的資訊了
實作執行任意一個預存程序傳回一個DataSet物件的具體函數程式碼
檔案名稱:TestSqlAccess. cs
// 在vs.net調試通過
using System;
using System.Data;
using System.Xml;
using System.Data.SqlClient;
using System.Data.OleDb ;
using System.Collections;using System.Data.OleDb ;
using System.Collections; namespace Erp

{

public sealed class TestSqlAccess
{
#region 取得預存程序參數集合
public static SqlParameter [] getParameters(string cnString,string proName)
{Connection
. );
SqlCommand comm=new SqlCommand();
comm.Connection =conn;
comm.CommandType =CommandType.StoredProcedure ;
comm.CommandText =proName;
SqlParameter[comm.Parameters.Count];
for (int i=0;i{

arPrm[i]=new SqlParameter();

arPrm[i].SqlDbType =comm. Parameters[i].SqlDbType ;
arPrm[i].ParameterName=comm.Parameters[i].ParameterName;
arPrm[i].Size =comm.Parameters[i].Size;
}
return ararPrm #endregion


#region 執行Command物件回傳DataSet



/////可以呼叫微軟提供的那個SqlHelper類別..


參數

  您可以使用DataReader 物件傳回唯讀的僅向前型資料流。 DataReader 中所包含的資訊可以來自一個預存程序。本範例使用 DataReader 物件執行具有輸入參數和輸出參數的預存程序,然後遍歷傳回記錄,查看回傳參數。


  1. 在運行Microsoft SQL Server 的伺服器上建立下面的預存程序: Create Procedure TestProcedure

  (

  @au_idIN 111), 11), )

  AS

  select A. au_fname, A.au_lname, T.title

  from authors as A join titleauthor as TA on

  A.au_id=TA.au_id氏

  A.au_id=TA。 .title_id

  where A. au_id=@au_idIN

  set @numTitlesOUT = @@Rowcount

  return (5)

  2. 新建一個Visual C# .NET Windows 應用程式專案。

  3. 對 System 和 System.Data 名稱空間使用 using 語句,這樣,在後面的程式碼中就不需要在這些名稱空間中限定聲明了。將此程式碼新增至"窗體"程式碼模組的頂部。請確保只複製對應於您所選的提供者的代碼。 SQL 客戶機using System.Data.SqlClient;

  OLE DB 資料提供者using System.Data.OleDb;

  4. 用以下程式碼取代private Form_Load 事件中的程式碼: SQL 客戶端系統"Data Source=server;integrated " +

  "Security=sspi;initial catalog=pubs;");

  SqlCommand testCMD = new SqlCommand

〜 SqlCommand testCMD = new SqlCommand

,$test. = CommandType.StoredProcedure ;

  SqlParameter RetVal = testCMD.Parameters.Add

  ("RetVal", SqlDbType.Int);

. testCMD.Parameters.Add

  ("@au_idIN" , SqlDbType.VarChar, 11);

  IdIn.Direction = ParameterDirection.Input;

  SqlParameter NumTitles = testCMD.Parameters.Addamml. );

  NumTitles.Direction = ParameterDirection .Output;

  IdIn.Value = "213-46-8915";

  PubsConn.Open();

  㜀接"Book Titles for this Author:" );

  while (myReader.Read())

  {

  Console.WriteLine ("{0}", myReader.GetString (I)); ();

  Console .WriteLine("Number of Rows:" + NumTitles.Value );

  Console.WriteLine("Return Value:" + RetVal.Value);

  OLE Con​​nection 資料提供者 Pubs DB SQLOLEDB;Data Source=server;" +

  "integrated Security=sspi;initial catalog=pubs;");

  OleDbCommand testCMD = new OleDbCommand

  OleDbCommand testCMD = new OleDbCommand

『㟎〜㟜S); testCMD.CommandType = CommandType. StoredProcedure;

  OleDbParameter RetVal = testCMD.Parameters.Add

(“RetVal”,OleDbType.Integer);RetVal.Direction = ParameterDirection.ReturnValue;

OleDbParameter IdIn = testCMD.Parameters.Add

IdIn.Direction = ParameterDirection.Input;

OleDbParameter NumTitles = testCMD.Parameters.Add

("@numtitlesout", OleDbType.VarChar, 111);

IdIn.Value = "213-46-第8915章{

佛Console.WriteLine("{0}", myReader.GetString(2));

佛};

myReader.Close);

佛Console.WriteLine("行數:" + NumTitles.Value ) ;

Console.WriteLine("Return Value:" + RetVal.Value);

5.ConnectionConnection:" + RetVal.Value);

5.ConnectionConnection指向執行SQL Server的電腦。 、傳回值5 和輸出參數,其中包含記錄的數目(2)。記錄。

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
c#vs. .net:澄清關鍵差異和相似之處c#vs. .net:澄清關鍵差異和相似之處May 01, 2025 am 12:12 AM

C#是一種編程語言,而.NET是一個軟件框架。 1.C#由微軟開發,適用於多平台開發。 2..NET提供類庫和運行時環境,支持多語言。兩者協同工作,構建現代應用。

超越炒作:評估C#.NET的當前作用超越炒作:評估C#.NET的當前作用Apr 30, 2025 am 12:06 AM

C#.NET是一個強大的開發平台,結合了C#語言和.NET框架的優勢。 1)它廣泛應用於企業應用、Web開發、遊戲開發和移動應用開發。 2)C#代碼編譯成中間語言後由.NET運行時環境執行,支持垃圾回收、類型安全和LINQ查詢。 3)使用示例包括基本控制台輸出和高級LINQ查詢。 4)常見錯誤如空引用和類型轉換錯誤可以通過調試器和日誌記錄解決。 5)性能優化建議包括異步編程和優化LINQ查詢。 6)儘管面臨競爭,C#.NET通過不斷創新保持其重要地位。

C#.NET的未來:趨勢和機遇C#.NET的未來:趨勢和機遇Apr 29, 2025 am 12:02 AM

C#.NET的未來趨勢主要集中在雲計算、微服務、AI和機器學習集成以及跨平台開發三個方面。 1)雲計算和微服務:C#.NET通過Azure平台優化雲環境表現,支持構建高效微服務架構。 2)AI和機器學習集成:借助ML.NET庫,C#開發者可在應用中嵌入機器學習模型,推動智能化應用發展。 3)跨平台開發:通過.NETCore和.NET5 ,C#應用可在Windows、Linux和macOS上運行,擴展部署範圍。

C#.NET開發今天:趨勢和最佳實踐C#.NET開發今天:趨勢和最佳實踐Apr 28, 2025 am 12:25 AM

C#.NET開發的最新動態和最佳實踐包括:1.異步編程提高應用響應性,使用async和await關鍵字簡化非阻塞代碼;2.LINQ提供強大查詢功能,通過延遲執行和表達式樹高效操作數據;3.性能優化建議包括使用異步編程、優化LINQ查詢、合理管理內存、提升代碼可讀性和維護性、以及編寫單元測試。

C#.NET:使用.NET生態系統構建應用程序C#.NET:使用.NET生態系統構建應用程序Apr 27, 2025 am 12:12 AM

如何利用.NET構建應用?使用.NET構建應用可以通過以下步驟實現:1)了解.NET基礎知識,包括C#語言和跨平台開發支持;2)學習核心概念,如.NET生態系統的組件和工作原理;3)掌握基本和高級用法,從簡單控制台應用到復雜的WebAPI和數據庫操作;4)熟悉常見錯誤與調試技巧,如配置和數據庫連接問題;5)應用性能優化與最佳實踐,如異步編程和緩存。

C#作為多功能.NET語言:應用程序和示例C#作為多功能.NET語言:應用程序和示例Apr 26, 2025 am 12:26 AM

C#在企業級應用、遊戲開發、移動應用和Web開發中均有廣泛應用。 1)在企業級應用中,C#常用於ASP.NETCore開發WebAPI。 2)在遊戲開發中,C#與Unity引擎結合,實現角色控制等功能。 3)C#支持多態性和異步編程,提高代碼靈活性和應用性能。

C#.NET用於網絡,桌面和移動開發C#.NET用於網絡,桌面和移動開發Apr 25, 2025 am 12:01 AM

C#和.NET適用於Web、桌面和移動開發。 1)在Web開發中,ASP.NETCore支持跨平台開發。 2)桌面開發使用WPF和WinForms,適用於不同需求。 3)移動開發通過Xamarin實現跨平台應用。

C#.NET生態系統:框架,庫和工具C#.NET生態系統:框架,庫和工具Apr 24, 2025 am 12:02 AM

C#.NET生態系統提供了豐富的框架和庫,幫助開發者高效構建應用。 1.ASP.NETCore用於構建高性能Web應用,2.EntityFrameworkCore用於數據庫操作。通過理解這些工具的使用和最佳實踐,開發者可以提高應用的質量和性能。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。