今天遇到一个需求,是根据逻辑判断动态创建局部临时表
1
declare
@flag
bit
2data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
3
select
@flag
=
1
4data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
5
--
当@flag=1时,临时表第2个字段a的类型为float
6
7
--
当@flag<>1时,临时表第2个字段a的类型为int
8
9
if
@flag
=
1
10data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
11
begin
12data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
13
create
table
#TemTable(ids
int
, a
float
)
14data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
15
end
16data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
17
else
18data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
19
begin
20data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
21
create
table
#TemTable(ids
int
,a
int
)
22data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
23
end
24data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
25
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
2
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
3
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
4
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
5
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
6
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
7
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
8
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
9
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
10
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
11
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
12
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
13
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
14
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
15
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
16
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
17
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
18
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
19
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
20
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
21
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
22
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
23
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
24
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
25
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
运行时出现错误提示如下:
服务器: 消息 2714,级别 16,状态 1,行 9
数据库中已存在名为 '#TemTable' 的对象。
看来创建临时表也和声明变量一样
想来想去,考虑了解决方式有2种:
1.命名2个不同的表名称
#TemTable1和#TemTable2
2.先创建表的基本结构,再根据条件修改表结构
1
declare
@flag
bit
2data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
3
select
@flag
=
1
4data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
5
create
table
#TemTable(ids
int
)
6data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
7
if
@flag
=
1
8data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
9
begin
10data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
11
alter
table
#TemTable
12data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
13
add
a
float
14data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
15
end
16data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
17
else
18data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
19
begin
20data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
21
alter
table
#TemTable
22data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
23
add
a
int
24data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
25
end
26data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
27
go
28data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
29
--
表结构改变后要重新编译
30
31
select
*
from
#TemTable
32data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
33
insert
into
#TemTable
34data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
35
select
1
,
1
36data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
37
drop
table
#TemTable
38
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
2
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
3
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
4
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
5
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
6
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
7
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
8
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
9
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
10
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
11
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
12
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
13
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
14
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
15
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
16
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
17
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
18
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
19
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
20
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
21
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
22
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
23
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
24
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
25
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
26
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
27
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
28
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
29
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
30
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
31
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
32
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
33
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
34
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
35
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
36
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
37
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
38
data:image/s3,"s3://crabby-images/7b284/7b2846d0efe425752e9e9393ca81317b3c8f563e" alt="局部临时表和表变量的重复创建问题随笔 局部临时表和表变量的重复创建问题随笔"
请注意表变量也会有这样的问题
希望上面提到的知识对你有所提示
当然欢迎交流和指正
blog:
http://www.cnblogs.com/aierong
author:aierong
email:aierong@126.com