程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> C# >> C#入門知識 >> C#調用自定義表類型參數

C#調用自定義表類型參數

編輯:C#入門知識

C#調用自定義表類型參數


-SQL SERVER生成測試環境:

 

--創建測試DB
CREATE database Sales;
go
USE Sales
GO
--創建表類型
IF TYPE_ID('LocalDT') IS NOT NULL
	DROP TYPE LocalDT
GO 
CREATE TYPE LocalDT AS TABLE
(
	ID INT NOT NULL,
	Name NVARCHAR(50)
)
GO
--創建存儲過程
IF OBJECT_ID('P_DataTable','P') IS NOT NULL
	DROP PROC P_DataTable;
GO

CREATE PROCEDURE P_DataTable
(
	@LocalDT LocalDT READONLY
)
AS
SELECT * FROM @LocalDT
GO


--打開Visual Studio—創建項目—選擇【控制台應用程序】

 

 

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data;
using System.Data.SqlClient;

namespace ProcDataTable
{
    class Program
    {
        static void Main(string[] args)
        {
            DataTable dt = new DataTable("LocalDT");
            dt.Columns.Add("ID",typeof(int));
            dt.Columns.Add("Name", typeof(string));
            DataRow dr = dt.NewRow();
            dr[0] = 1;
            dr[1] = "Roy";
            dt.Rows.Add(dr);
            SqlConnection thisConnection = new SqlConnection(@"Server=實例名;Database=Sales;User ID=sa;Password=1");
            thisConnection.Open();
            SqlCommand sqlcmd = thisConnection.CreateCommand();
            sqlcmd.CommandType = CommandType.StoredProcedure;
            sqlcmd.CommandText = "P_DataTable";
            SqlParameter param = sqlcmd.Parameters.AddWithValue("@LocalDT", dt);
            SqlDataReader sdr = sqlcmd.ExecuteReader();
            while (sdr.Read())
            {
                Console.WriteLine("ID:{0}\tName:{1}",sdr[0],sdr[1]);
            }
            thisConnection.Close();  
            Console.ReadKey();  
        }
    }
}

--測試結果:

 

\

 

 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved