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();
        }
    }
}

--測试结果:

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" />

时间: 2024-11-04 17:46:19

C#调用自己定义表类型參数的相关文章

SQL 用户定义表类型,在存储过程里使用数据类型作參数

在数据库编程里使用数据类型,能够提高代码的重用性.它们常常被使用在方法和存储过程中.使用数据类型,我们能够避免在存储过程里定义一串的參数,让人眼花缭乱,它就相当于面向对象语言里.向一个方法里传入一个对象,而该对象有各种属性,存储过程仅仅须要获取这个对象就能获取到各个參数,然后做出对应的处理.有所不同的是SQL的表类型是能够包括多条数据的.到底是怎么一回事,且看以下的样例. 1. 首先我创建了一个学生表,包括四个字段,主键是从1開始的自增长型. GO CREATE TABLE STUDENT( I

Scala入门到精通——第二十节 类型參数(二)

本节主要内容 Ordering与Ordered特质 上下文界定(Context Bound) 多重界定 类型约束 1. Ordering与Ordered特质 在介绍上下文界定之前,我们对scala中的Ordering与Ordered之间的关联与差别进行解说,先看Ordering.Ordered的类继承层次体系: 通过上面两个图能够看到,Ordering混入了java中的Comparator接口.而Ordered混入了java的Comparable接口.我们知道java中的Comparator是一

[javase学习笔记]-6.5 类类型參数与匿名对象

这一节我们来说说类类型參数和匿名对象. 我们继续用之前的小汽车类吧 class Car { int num;//这是轮胎数属性 String color;//这是颜色属性 String brand;//这是品牌性 void start()//启动行为 { System.out.println("小汽车已启动"); } void run()//这就是执行行为 { System.out.println(num+"..."+color+"..."+br

springmvc学习笔记(13)-springmvc注解开发之集合类型參数绑定

springmvc学习笔记(13)-springmvc注解开发之集合类型參数绑定 springmvc学习笔记13-springmvc注解开发之集合类型參数绑定 数组绑定 需求 表现层实现 list绑定 需求 表现层实现 map绑定 本文主要介绍注解开发的集合类型參数绑定,包含数组绑定,list绑定以及map绑定 数组绑定 需求 商品批量删除,用户在页面选择多个商品.批量删除. 表现层实现 关键:将页面选择(多选)的商品id,传到controller方法的形參,方法形參使用数组接收页面请求的多个商

Sqlserver 自定义表类型定义,使用,删除

--创建用户自定义表类型CREATE TYPE dbo.CustomerTable AS TABLE ( Id int NOT NULL, Name char(10) NULL, PRIMARY KEY (Id))---使用用户自定义表类型DECLARE @c CustomerTableINSERT INTO @c VALUES(1,'Xizhang')SELECT * FROM @c --判断自定义表是否存在IF TYPE_ID('CustomerTable') IS NOT NULL --删

可变參数学习笔记

一.什么是可变參数 我们在C语言编程中有时会遇到一些參数个数可变的函数,比如printf()函数,其函数原型为: int printf( const char* format, ...); 它除了有一个參数format固定以外,后面跟的參数的个数和类型是可变的(用三个点"-"做參数占位符),实际调用时能够有下面的形式: printf("%d",i); printf("%s",s); printf("the number is %d ,s

Swift 泛型參数

原文:http://www.cocoachina.com/newbie/basic/2014/0612/8802.html 本页内容包含:泛型形參语句和泛型实參语句 本节涉及泛型类型.泛型函数以及泛型构造器的參数,包含形參和实參.声明泛型类型.函数或构造器时,须指定对应的类型參数.类型參数相当于一个占位符,当实例化泛型类型.调用泛型函数或泛型构造器时,就用详细的类型实參替代之. 关于 Swift 语言的泛型概述,见泛型(第二部分第22章). 泛型形參语句 泛型形參语句指定泛型类型或函数的类型形參

将方法作为方法的參数 —— 理解托付

<.NET开发之美>上对于托付写到:"它们就像是一道槛儿,过了这个槛的人,认为真是太easy了,而没有过去的人每次见到托付和事件就认为心里别得慌,混身不自在."我认为这句话就像是在说我自己一样.于是我决定好好看看关于这方面的知识. 一.托付与接口 事实上非常多时候我感觉托付所起的作用与定义一个仅仅是含有一个方法的接口全然一样的.他们实现的功能是同样的. 如果有这样一个样例: 事实上这个样例非常easy,就是定义了一个IGreeting接口,里面有一个Greetingpeop

linux kernel的cmdline參数解析原理分析

利用工作之便,今天研究了kernel下cmdline參数解析过程.记录在此.与大家共享.转载请注明出处.谢谢. Kernel 版本:3.4.55 Kernel启动时会解析cmdline,然后依据这些參数如console root来进行配置执行. Cmdline是由bootloader传给kernel.如uboot.将须要传给kernel的參数做成一个tags链表放在ram中,将首地址传给kernel,kernel解析tags来获取cmdline等信息. Uboot传參给kernel以及kerne