替换Cursors和While Loops

一般在处理循环问题的时候,大家都会选择Cursor,因为使用起来非常方便,代码也很好实现,但是使用Cursor肯能会产生性能问题。那么有什么好的替代方法吗?从网上看到的一篇文章很有借鉴意义(ReplacingCursors and While Loops),改写Cursor性能提高了几倍.

 

所以我们在设计代码的时候可以多考虑考虑是否不用Cursor也可以实现。 源代码和改写后的代码如下:

 

--源代码先查询r查询@tmp_id然后跟据@tmp_id获得tmp_values然后更新表OutPut_tbl的值

             

            DECLARE temp_cursor CURSOR FOR

            SELECT column_data

            FROM DB.dbo.many_tbl

            WHERE id = @tmp_id  -- key data

            ORDER BY column_data

 

            OPEN temp_cursor

 

            FETCH NEXT FROM temp_cursor

 

            INTO @tmp_data

 

            WHILE @@FETCH_STATUS = 0

 

            BEGIN

   

            SELECT @tmp_values = @tmp_values + convert(varchar(20), @tmp_data) + ','

 

            FETCH NEXT FROM temp_cursor

            INTO @tmp_data

            END

 

            CLOSE temp_cursor

            DEALLOCATE temp_cursor

 

            UPDATE DB.dbo.OutPut_tbl

            SET column_out = @tmp_values

            WHERE id = @tmp_id

 

--替换代码(速度变快而且代码简洁)

 

CREATE function dbo.ufn_data_pivot(@id as int)

      Returns varchar(20)

      AS

      BEGIN

          DECLARE @value varchar(20)

          SET @value = ''

          SELECT  @value =  @value + convert(varchar(20), column_data) + ','

          FROM DB.dbo.many_tbl

          WHERE id = @id

          ORDER BY column_data

 

          Return @value

      END

 

UPDATE DB.dbo.OutPut_tbl

SET column_out= dbo.ufn_data_pivot(key_column)

 

 

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值