C# 讀取在存儲過程多結果集

--SQL Server 測試環境搭建:sql

 

Create database Test; 
go
USE [Test]
GO
if OBJECT_ID('Tab','U') is not null
	drop table Tab
go
CREATE TABLE [dbo].[Tab](
	[ID] [int] identity(1,1) NOT NULL,
	[name] [sysname] NOT NULL,
)
go
if OBJECT_ID('Tab2','U') is not null
	drop table Tab2
go
CREATE TABLE [dbo].[Tab2](
	[ID] [int] IDENTITY(1,1) NOT NULL,
	[TabID] [int] NOT NULL,
	[Name2] [nvarchar](50) NULL
) ON [PRIMARY]
GO

--建立存儲過程:ide

 

 

if OBJECT_ID('P3','P') is not null
	drop procedure P3
go
create procedure P3
as
select * from Tab;
select * from Tab2;

--打開Visual Studio—建立項目—選擇【控制檯應用程序】測試

 

 

#region Using Directives
using System;
using System.Data;
using System.Data.SqlClient;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
#endregion

namespace TestReadingStoreProc
{
    class Program
    {
        static void Main(string[] args)
        {
            SqlConnection thisConnection = new SqlConnection(@"Server=(Local);Database=Test;User ID=sa;Password=1");  
            SqlCommand thisCommand = thisConnection.CreateCommand();
            thisCommand.CommandType = CommandType.StoredProcedure;
            thisCommand.CommandText = "P3";
            SqlDataAdapter thisAdapter = new SqlDataAdapter(thisCommand);
            DataSet thisDataSet = new DataSet();
            thisAdapter.Fill(thisDataSet);
            if (thisDataSet.Tables.Count > 0)
            {
                Console.WriteLine("Table Name:{0}\nTable Rows:{1}",thisDataSet.Tables[0].TableName, thisDataSet.Tables[0].Rows.Count);
                Console.WriteLine("Table Name:{0}\nTable Rows:{1}", thisDataSet.Tables[1].TableName, thisDataSet.Tables[1].Rows.Count);
            }
            thisConnection.Close();
            Console.ReadKey();
        }
    }
}



 

----按F5運行結果:

this

相關文章
相關標籤/搜索