最近一向在做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 (编辑:湖南网)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|