Heim > Datenbank > MySQL-Tutorial > Wie übergebe ich mithilfe von ADO.NET Tabellenwertparameter an gespeicherte Prozeduren?

Wie übergebe ich mithilfe von ADO.NET Tabellenwertparameter an gespeicherte Prozeduren?

Barbara Streisand
Freigeben: 2025-01-11 10:57:42
Original
1028 Leute haben es durchsucht

How to Pass Table-Valued Parameters to Stored Procedures using ADO.NET?

Verwenden von ADO.NET zum Übergeben von Tabellenwertparametern an gespeicherte Prozeduren

Tabellenwertige Parameter bieten eine optimierte Methode zum Übergeben von Datensätzen an gespeicherte Prozeduren. Dieser Leitfaden zeigt, wie diese Funktionalität in ADO.NET implementiert wird.

1. Definieren eines benutzerdefinierten Tabellentyps in SQL Server

Erstellen Sie zunächst einen benutzerdefinierten Tabellentyp in Ihrer SQL Server-Datenbank, der als Struktur für Ihren Tabellenwertparameter dient:

<code class="language-sql">CREATE TYPE [dbo].[MyDataType] As Table
(
    ID INT,
    Name NVARCHAR(50)
)</code>
Nach dem Login kopieren

2. Erstellung gespeicherter Prozeduren

Als nächstes erstellen Sie eine gespeicherte Prozedur, die diesen benutzerdefinierten Tabellentyp als Parameter akzeptiert:

<code class="language-sql">CREATE PROCEDURE [dbo].[MyProcedure]
(
    @myData [dbo].[MyDataType] READONLY
)
AS
BEGIN
    SELECT * FROM @myData
END</code>
Nach dem Login kopieren

3. DataTable-Konstruktion in C#

Erstellen Sie in Ihrem C#-Code eine Datentabelle, um die Struktur Ihres SQL Server-Tabellentyps widerzuspiegeln:

<code class="language-csharp">DataTable myDataTable = new DataTable("MyDataType");
myDataTable.Columns.Add("Name", typeof(string));
myDataTable.Columns.Add("Id", typeof(int));
myDataTable.Rows.Add("XYZ", 1);
myDataTable.Rows.Add("ABC", 2);</code>
Nach dem Login kopieren

4. SqlParameter-Konfiguration

Erstellen Sie abschließend ein SqlParameter-Objekt und konfigurieren Sie es so, dass es Ihren Tabellenwertparameter darstellt:

<code class="language-csharp">SqlParameter parameter = new SqlParameter();
parameter.ParameterName = "@myData";
parameter.SqlDbType = System.Data.SqlDbType.Structured;
parameter.TypeName = "[dbo].[MyDataType]"; // Specify the type name
parameter.Value = myDataTable;
command.Parameters.Add(parameter);</code>
Nach dem Login kopieren

Indem Sie diese Schritte befolgen, können Sie mithilfe von ADO.NET Tabellenwertparameter effizient an Ihre gespeicherten Prozeduren übergeben. Denken Sie daran, [dbo].[MyDataType] durch den tatsächlichen Namen Ihres benutzerdefinierten Tabellentyps zu ersetzen.

Das obige ist der detaillierte Inhalt vonWie übergebe ich mithilfe von ADO.NET Tabellenwertparameter an gespeicherte Prozeduren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage