您好,欢迎来到思海网络,我们将竭诚为您提供优质的服务! 诚征网络推广 | 网站备案 | 帮助中心 | 软件下载 | 购买流程 | 付款方式 | 联系我们 [ 会员登录/注册 ]
促销推广
客服中心
业务咨询
有事点击这里…  531199185
有事点击这里…  61352289
点击这里给我发消息  81721488
有事点击这里…  376585780
有事点击这里…  872642803
有事点击这里…  459248018
有事点击这里…  61352288
有事点击这里…  380791050
技术支持
有事点击这里…  714236853
有事点击这里…  719304487
有事点击这里…  1208894568
有事点击这里…  61352289
在线客服
有事点击这里…  531199185
有事点击这里…  61352288
有事点击这里…  983054746
有事点击这里…  893984210
当前位置:首页 >> 技术文章 >> 文章浏览
技术文章

SQL Server传送数组参数的变通办法

添加时间:2014-5-17 8:03:08  添加: 思海网络 

最近一直在做Dnn模块的开发,过程中碰到这么一个问题,需要同时插入N条数据,不想在程序里控制,但是SQL Sever又不支持数组参数.所以只能用变通的办法了.利用SQL Server强大的字符串处理传把数组格式化为类似"1,2,3,4,5,6"。然后在存储过程中用SubString配合CharIndex把分割开来.

详细的存储过程 

CREATE PROCEDURE dbo.ProductListUpdateSpecialList 
@ProductId_Array varChar(800), 
@ModuleId int 
AS 
DECLARE @PointerPrev int 
DECLARE @PointerCurr int 
DECLARE @TId int 
Set @PointerPrev=1 
set @PointerCurr=1 

begin transaction 
Set NoCount ON 
delete from ProductListSpecial where ModuleId=@ModuleId 

Set @PointerCurr=CharIndex(',',@ProductId_Array,@PointerPrev+1) 
set @TId=cast(SUBSTRING(@ProductId_Array,@PointerPrev,@PointerCurr-@PointerPrev) as int) 
Insert into ProductListSpecial (ModuleId,ProductId) Values(@ModuleId,@TId) 
SET @PointerPrev = @PointerCurr 
while (@PointerPrev+1 < LEN(@ProductId_Array)) 
Begin 
Set @PointerCurr=CharIndex(',',@ProductId_Array,@PointerPrev+1) 
if(@PointerCurr> 0) 
Begin 
set @TId=cast(SUBSTRING(@ProductId_Array,@PointerPrev+1,@PointerCurr-@PointerPrev-1) as int) 
Insert into ProductListSpecial (ModuleId,ProductId) Values(@ModuleId,@TId) 
SET @PointerPrev = @PointerCurr 
End 
else 
Break 
End 

set @TId=cast(SUBSTRING(@ProductId_Array,@PointerPrev+1,LEN(@ProductId_Array)-@PointerPrev) as int) 
Insert into ProductListSpecial (ModuleId,ProductId) Values(@ModuleId,@TId) 
Set NoCount OFF 
if error=0 
begin 
commit transaction 
end 
else 
begin 
rollback transaction 
end 
GO


网友Bizlogic对此的改进方法:

应该用SQL2000 OpenXML更简单,效率更高,代码更可读: 

CREATE Procedure [dbo].[ProductListUpdateSpecialList] 

@ProductId_Array NVARCHAR(2000), 
@ModuleId INT 


AS 

delete from ProductListSpecial where ModuleId=@ModuleId 

-- If empty, return 
IF (@ProductId_Array IS NULL OR LEN(LTRIM(RTRIM(@ProductId_Array))) = 0) 
RETURN 

DECLARE @idoc int 

EXEC sp_xml_preparedocument @idoc OUTPUT, @ProductId_Array 

Insert into ProductListSpecial (ModuleId,ProductId) 
Select 
@ModuleId,C.[ProductId] 
FROM 
OPENXML(@idoc, '/Products/Product', 3) 
with (ProductId int ) as C 
where 
C.[ProductId] is not null 

EXEC sp_xml_removedocument @idoc

关键字:SQL Server、数组参数、模块

分享到:

顶部 】 【 关闭
版权所有:佛山思海电脑网络有限公司 ©1998-2024 All Rights Reserved.
联系电话:(0757)22630313、22633833
中华人民共和国增值电信业务经营许可证: 粤B1.B2-20030321 备案号:粤B2-20030321-1
网站公安备案编号:44060602000007 交互式栏目专项备案编号:200303DD003  
察察 工商 网安 举报有奖  警警  手机打开网站