3

我在 while 循环中有 while 循环,两个循环都对一张表进行了一些修改。我收到一个表已经存在的错误。下面这个问题的简单例子。有人可以澄清为什么这不起作用吗?我知道在这种特殊情况下如何绕过这个问题,但我想了解它是从哪里来的。

CREATE TABLE #a(
  ID int)

DECLARE @i INT
DECLARE @j INT  

SET @i = 1
SET @j = 1

WHILE @i < 10
BEGIN

    SELECT  *
    INTO #b
    FROM  #a

    DROP TABLE #b

    WHILE @j < 10 BEGIN
        SELECT  *
        INTO #b
        FROM  #a

        DROP TABLE #b

        SET @j = @j + 1
    END

  SET @i = @i + 1
END
4

1 回答 1

1

正如 Sean Lange 指出的那样,您可以在没有循环的情况下做任何事情。

同一过程中不能有两条语句创建同名的临时表。这是 SQL 6.5 的遗留物,没有延迟名称解析。

而不是使用select into,使用create table + insert

不要删除和重新创建具有相同架构的同一张表,而是使用truncate table.

Erland Sommarskog 在 MSDN Social 上的回答

create table #a(ID int);
create table #b(ID int);
declare @i int;
declare @j int;
set @i = 1;
set @j = 1;
while @i < 10
  begin;
    insert into #b (id)
      select id
      from #a;

    truncate table #b;

    while @j < 10
      begin;
        insert into #b (id)
          select id
          from #a

        truncate table #b;

        set @j = @j + 1;
      end;
    set @i = @i + 1;
  end;
于 2017-03-13T15:08:29.950 回答