如何在sql中实现do-while循环

时间:2009-10-03 03:43:25

标签: sql sql-server tsql while-loop flow-control

我正在尝试计算如何在TSQL中实现它

do 
  update stuff set col = 'blah' where that_row = 'the right one'
  select trash from stuff ...
until some_condition

Transact-SQL提供的唯一迭代控制流句是while (condition) sentences,它首先评估条件,如果该条件为真则执行句子。

我正在思考如何在表上执行UPDATE语句,直到某些条件被触发,直到执行了最后一次UPDATE。

最重要的是,我正在寻找解决这个问题的不那么肮脏的方法(在WHILE之前复制UPDATE对我来说没有多大意义,因为UPDATE语句可以任意长而复杂)


编辑:我正在尝试解决的问题涉及同一个表下的多个UPDATE语句,每个语句都采用并转换前一次迭代中的值。这在一个大的UPDATE语句中是不可能的,因为每行只会被评估和更新一次,所以循环是我能弄清楚这个混乱的唯一方法。

1 个答案:

答案 0 :(得分:41)

这实际上是一个Do-While循环:

WHILE (1=1)
  BEGIN

  -- Do stuff...

  IF (some_condition is true)
     BREAK;

  END

但正如@Joel Coehoorn指出的那样,总是首先尝试使用基于集合的方法。如果我想不出使用set操作解决问题的方法,我只会求助于循环。