sqlserver 用户定义表类型

有时需要将内存中的表与数据库中的表比较,比如Datatable中有100行数据,需要判断在数据库中是否存在,这个时候我们就可以使用sqlserver中的【用户 定义表类型】

这里最最最重要的思路是把【用户 定义表类型】当作一张虚拟的正常表去处理

 

 

 

需求:现在内存中有个Datatable,数据库中有张表【TempUser】,需要在内存中取出 Datatable和【TempUser】相同ID的TempUser的信息

实现:

1、新建表

CREATE TABLE TempUser(
ID INT NOT NULL IDENTITY(1,1) PRIMARY KEY,
NAME NVARCHAR(100),
Age INT
)

INSERT    TempUser VALUES('a',1)
INSERT    TempUser VALUES('b',2)
INSERT    TempUser VALUES('c',3)

2、新建【用户表类型】

 

CREATE TYPE temp_20190915 AS TABLE 
(
    ID INT
)

 

3、新建存储过程

CREATE PROC proc_test_20190915(@temp_20190915 temp_20190915 readonly)
AS
BEGIN
SELECT b.* FROM @temp_20190915 a JOIN TempUser b ON a.ID=b.IDEND

注意事项:存储过程的参数类型是刚刚新建的【用户表类型】并且是只读的

此时在存储过程中我们可以把【用户表类型】当作一张正常表的去处理需要的数据(注意是只读)

4、内存中构建我们的Datatable

            var data = new DataTable();
            data.Columns.Add("id", typeof(int));var row1 = data.NewRow();
            row1["id"] = 1;
            data.Rows.Add(row1);

            var row2 = data.NewRow();
            row2["id"] = 2; 
            data.Rows.Add(row2);

 

5、调用存储过程

var p = new System.Data.SqlClient.SqlParameter[1];
p[0] = new System.Data.SqlClient.SqlParameter("@temp_20190915", data);

var data= Comm.Tool.DbHelper.ExecProcDataSet("proc_test_20190915", p, "数据库连接").Tables[0];
 1 public static DataSet ExecProcDataSet(string procName, SqlParameter[] parameters, string connStr)
 2         {
 3             using (SqlConnection conn = new SqlConnection(connStr))
 4             {
 5                 conn.Open();
 6                 SqlCommand cmd = GetSqlCommand(conn, procName, CommandType.StoredProcedure, parameters);
 7                 cmd.CommandTimeout = 0;
 8                 SqlDataAdapter da = new SqlDataAdapter(cmd);
 9                 DataSet ds = new DataSet();
10                 da.Fill(ds);
11                 cmd.Dispose();
12                 return ds;
13             }
14         }
ExecProcDataSet

 

6、调试可以看到data就是我们需要的数据

 

总结:【用户 定义表类型】的方便之处就是可以将内存中Datatable很好的很数据库中的表结合

 

转载于:https://www.cnblogs.com/xiao-sheng/p/11521682.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值