SqlServer存储过程传入Table参数
今天是周日,刚好有空闲时间整理一下这些天工作业务中遇到的问题。
有时候我们有这样一个需求,就是在后台中传过来一个IList<类>的泛型集合数据,该集合是某个类的实例集合体,然后将该集合中的实例的数据一个个地插入到数据库或者更新到数据库中去。一开始我想到的方法是拼接字符串,然后通过存储过程对接收到的字符串进行截取,再一个个地插入或者更新到数据库中去,这是最原始的方法,不过过程会比较复杂,想到这就头疼。后来查找发现说SqlServer2008中为存储过程添加了一个新特性,可以传递表类型的参数,既然可以传递表类型参数,那问题就变得简单啦。以下是开发中写的code.
1.asp.net后台:
/// <summary>
/// Add the PayrollCycle
/// </summary>
/// <param name="payrollCycle">payrollCycle</param>
/// <returns>bool</returns>
public bool AddPayrollCycle(IList<PayrollCycle> payrollCycles)
{
DataTable dataTable=new DataTable();
dataTable.Columns.Add("Year",typeof(int));
dataTable.Columns.Add("Month",typeof(int));
dataTable.Columns.Add("CutoffDate",typeof(int));
dataTable.Columns.Add("PayrollDate",typeof(int));
dataTable.Columns.Add("EnterUser",typeof(string));
dataTable.Columns.Add("EnterDate",typeof(DateTime));
dataTable.Columns.Add("LastUpdatedUser",typeof(string));
dataTable.Columns.Add("LastUpdatedDate",typeof(DateTime));
foreach (PayrollCycle p in payrollCycles)
{
DataRow dataRow = dataTable.NewRow();
dataRow["Year"] = p.Year;
dataRow["Month"] = p.Month;
dataRow["CutoffDate"] = p.CutoffDate;
dataRow["PayrollDate"] = p.PayrollDate;
dataRow["EnterUser"] = UserSession.LogOnUserAccount;
dataRow["EnterDate"] = DateTime.Now;
dataRow["LastUpdatedUser"] = UserSession.LogOnUserAccount;
dataRow["LastUpdatedDate"] = DateTime.Now;
dataTable.Rows.Add(dataRow);
} SqlParameter[]paras=new SqlParameter[]
{
new SqlParameter("@PayrollCycles",dataTable)
};
return SqlHelper.ExecuteNonQuery("MCU.USP_AddPayrollCycles", paras) > ;
}
为dataTable添加column的时候,必须明确该列的typeof,否则在存储过程当中会把传入的该列当成varchar类型看待,导致某些类型转换失败
2.在SqlServer中先定义一个Table类型的Type:
CREATE TYPE [PayrollCycleType] AS TABLE(
[YEAR] [int] NOT NULL,
[Month] [int] NOT NULL,
[CutoffDate] [int] NOT NULL,
[PayrollDate] [int] NOT NULL,
[EnterUser] [varchar]() NULL,
[EnterDate] [datetime] NULL,
[LastUpdatedUser] [varchar]() NULL,
[LastUpdatedDate] [datetime] NULL
)
GO
接着编写一个传入上步骤中定义的表类型的参数的存储过程,该参数为Readonly(作为表类型参数必须为可读),代码如下:
插入操作:
CREATE PROCEDURE [MCU].[USP_AddPayrollCycles]
(
@PayrollCycles MCU.PayrollCycleType Readonly
)
AS
BEGIN
SET NOCOUNT ON
BEGIN TRANSACTION
INSERT INTO MCU.PayrollCycle
( [Year] ,
[Month] ,
CutoffDate ,
PayrollDate ,
EnterUser ,
EnterDate ,
LastUpdatedUser ,
LastUpdatedDate
)
SELECT [Year] ,
[Month] ,
CutoffDate ,
PayrollDate ,
EnterUser ,
EnterDate ,
LastUpdatedUser ,
LastUpdatedDate
FROM @PayrollCycles
COMMIT TRANSACTION
END GO
更新操作:
CREATE PROCEDURE [MCU].[USP_UpdatePayrollCycle]
(
@PayrollCycles MCU.PayrollCycleType READONLY,
@TypeOfDate NVARCHAR()
)
AS
BEGIN
SET NOCOUNT ON
--declare an table
DECLARE @temp AS MCU.PayrollCycleType
--insert into @temp from @PayrollCycles
INSERT INTO @temp
( [YEAR] ,
[Month] ,
CutoffDate ,
PayrollDate
)
SELECT
[YEAR] ,
[Month] ,
CutoffDate ,
PayrollDate
FROM @PayrollCycles --Update the PayrollCycle
IF(@TypeOfDate='Payroll')
BEGIN
UPDATE MCU.PayrollCycle
SET
PayrollDate=t.PayrollDate
FROM
@temp t
WHERE MCU.PayrollCycle.[Year]=t.[Year] AND MCU.PayrollCycle.[Month]=t.[Month]
END IF(@TypeOfDate='Cut-off')
BEGIN
UPDATE MCU.PayrollCycle
SET
CutoffDate=t.CutOffDate
FROM @temp t
WHERE MCU.PayrollCycle.[Year]=t.[Year] AND MCU.PayrollCycle.[Month]=t.[Month]
END
END GO
就这样大功告成,用起来相当方便,就不用通过拼接字符串进行数据的插入,更新操作了。
SqlServer存储过程传入Table参数的更多相关文章
- PROCEDURE存储过程传入表参数
) ,itemNum ) ,itemQty )) ---2.创建一个存储过程以表值参数作为输入 alter proc usp_TestProcWithTable @tb LocationTa ...
- clob字段的值插入和查询N种方法【包括java调用存储过程传入clob参数】
import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.IOException; import jav ...
- SQL 存储过程 传入数组参数
今天在做统计数据的时候,传入数组导致数据不显示.解决方式和大家分享一下: --参数@CompanyName='北京,天津,上海' DECLARE @PointerPrev int DECLAR ...
- SQLSERVER 根据传入的参数拼接sql语句字符串,反馈结果集
ALTER PROCEDURE [dbo].[usp_visit_detail](@siteid BIGINT, @Startime VARCHAR(15), @Endtime VARCHAR(15 ...
- php通过存储过程传入汉字参数并写入数据库
写入数据库,汉字为???样式的乱码,后根据网上介绍的方法,参数前加N,数据库汉字内容变成空白. 解决方法,在PHP中先转为base64,再在mysql中base64解码,前提先保证mysql中有bas ...
- sqlserver 存储过程 带输出参数
CREATE PROCEDURE [dbo].[output] @acctNbr varchar(), --会员卡号 @acctPwd1 nvarchar() OUT, --登录密码 @acctPwd ...
- SQLSERVER procedure 传入参数为DataTable类型 C#该怎么写
以上为数据库中存储过程传入参数为table类型 table类型在数据库中存在为: 最后在C#实现方式为:
- SQLSERVER存储过程语法详解
CREATE PROC [ EDURE ] procedure_name [ ; number ] [ { @parameter data_type } [ VARYING ] [ = default ...
- 创建并在项目中调用SQLSERVER存储过程的简单示例
使用SQLSERVER存储过程可以很大的提高程序运行速度,简化编程维护难度,现已得到广泛应用.创建存储过程 和数据表一样,在使用之前需要创建存储过程,它的简明语法是: 引用: Create PROC ...
随机推荐
- Windows命令行(DOS命令)教程-5 (转载)http://arch.pconline.com.cn//pcedu/rookie/basic/10111/15325_4.html
5. copy copy在英文中是复制的意思 [功能] 复制一个或一组文件到指定的磁盘或目录中 [格式] copy [C:][path][filename.ext] [C:][path]filenam ...
- silverlight 打印
加引用: using System.Windows.Printing; xaml文件里: //定义图片和文本打印变量 PrintDocument printImage; public BeginCo ...
- Unable to open log device '/dev/log/main': No such file or directory
在我们使用真机进行Android应用调试时,无法获得调试信息,错误提示如下:Unable to open log device '/dev/log/main': No such file or dir ...
- iOS 关于时间戳的一些细节
最近遇到一个bug,在iPhone上获取当前的时间戳,没有问题,而用iPad来测试的时候,出现了时间戳不对.当时的代码 (需要精确到毫秒,所以*1000) NSTimeInterval t = [[N ...
- git命令简图
基本概念 版本库(repository)=.git目录 工作区(working)=当前工作的目录 暂存区(stage)=临时缓存 图示 仓库操作 分支操作 工作区操作 参考链接(相当好) http:/ ...
- Big Event in HDU(HDU 1171 多重背包)
Big Event in HDU Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others ...
- Linux中重命名文件
linux下重命名文件有两种方式: 1.较简单的处理命令:mv mv 原文件名 新文件名 如:mv myFile newName 将MyFile重命名为newName. 2.linux提供了一个重命名 ...
- android中handler使用应该注意的问题(解决由handler引起的OOM内存泄漏)
最近,在项目过程中频繁的使用handler处理一些ui线程上的操作,以及使用handler的postdealy.然而使用过后却不对handler进行处理,进而产生了内存溢出现象,通过google,发现 ...
- POJ 2778 DNA Sequence (AC自动机,矩阵乘法)
题意:给定n个不能出现的模式串,给定一个长度m,要求长度为m的合法串有多少种. 思路:用AC自动机,利用AC自动机上的节点做矩阵乘法. #include<iostream> #includ ...
- gridview列显示,截取其中前面的几个字显示出来,当鼠标放上去的时候显示全部——使用LinkButton的方法
使用LinkButton的方法<asp:LinkButton ToolTip ='<%#Eval("FilePath") %>' runat="serv ...