博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
局部临时表和表变量的重复创建问题随笔
阅读量:7050 次
发布时间:2019-06-28

本文共 1703 字,大约阅读时间需要 5 分钟。

今天遇到一个需求,是根据逻辑判断动态创建局部临时表
 1declare @flag bit  
 2 
 3select @flag=1  
 4 
 5--当@flag=1时,临时表第2个字段a的类型为float  
 6 
 7--当@flag<>1时,临时表第2个字段a的类型为int  
 8 
 9if @flag=1  
10 
11begin  
12 
13       create table #TemTable(ids int,   a float)  
14 
15end  
16 
17else  
18 
19begin  
20 
21       create table #TemTable(ids int,a int)  
22 
23end  
24 
25
 
 
运行时出现错误提示如下:
服务器: 消息 2714,级别 16,状态 1,行 9
数据库中已存在名为 '#TemTable' 的对象。
 
看来创建临时表也和声明变量一样
 
想来想去,考虑了解决方式有2种:
 
1.命名2个不同的表名称
#TemTable1和#TemTable2
 
2.先创建表的基本结构,再根据条件修改表结构
 1declare @flag bit  
 2 
 3select @flag=1  
 4 
 5create table #TemTable(ids int)  
 6 
 7if @flag=1  
 8 
 9begin  
10 
11       alter table #TemTable  
12 
13              add a float  
14 
15end  
16 
17else  
18 
19begin  
20 
21       alter table #TemTable  
22 
23              add a int  
24 
25end  
26 
27go  
28 
29--表结构改变后要重新编译  
30 
31select * from #TemTable  
32 
33insert into #TemTable  
34 
35       select 1,1  
36 
37drop table #TemTable  
38
请注意表变量也会有这样的问题 
希望上面提到的知识对你有所提示
当然欢迎交流和指正
 
blog:
http://www.cnblogs.com/aierong
author:aierong
email:aierong@126.com
 
我的系列文章
A.Sql Server2005 Transact-SQL 新兵器学习 
B.MCAD学习 
C.代码阅读总结 
D.ASP.NET状态管理 
E.DB(数据库) 
F.WAP 
G.WinForm 
H.Flex
我的好文推荐
FlexAir开源版-全球免费多人视频聊天室,免费网络远程多人视频会议系统((Flex,Fms3联合开发))<视频聊天,会议开发实例8> 
Sql Server2005 Transact-SQL 新兵器学习总结之-总结 
MS SQL数据库备份和恢复存储过程(加强版本) 
sql server中分布式查询随笔(链接服务器(sp_addlinkedserver)和远程登录映射(sp_addlinkedsrvlogin)使用小总结) 
ASP.NET2.0国际化/本地化应用程序的实现总结(多语言,多文化页面的实现) 
WAP开发资料站(最新更新) 
自定义格式字符串随笔 (IFormattable,IFormatProvider,ICustomFormatter三接口的实现) 
Mcad学习笔记之异步编程(AsyncCallback 委托,IAsyncResult接口,BeginInvoke方法,EndInvoke方法的使用小总结) 
Mcad学习笔记之通过反射调用類的方法,屬性,字段,索引器(2種方法) 
Mcad学习笔记之序列化(2进制和Soap序列 化) 
Mcad学习笔记之委托再理解(delegate的构造器,BeginInvoke,EndInvoke,Invoke4个方法的探讨) 
ASP.NET状态管理之一(概括篇) 
Flex,Fms学习笔记
本文转自aierong博客园博客,原文链接:http://www.cnblogs.com/aierong/archive/2005/04/22/143280.html,如需转载请自行联系原作者
你可能感兴趣的文章
【算法介绍】哈希排序算法
查看>>
js数组操作(增、删、改、查)
查看>>
UpdatePanel and JQuery Plugin
查看>>
centos5.7下的kdump
查看>>
[JavaEE笔记]Cookie
查看>>
【HDOJ】1987 Decoding
查看>>
ELK+Filebeat (1)
查看>>
leetcode 443. String Compression
查看>>
在没联网环境下,启动tomcat出错
查看>>
关于Git bash-127.0.0.7:8888拒绝访问的小问题--环境变量
查看>>
Java EE(七)
查看>>
javascript变量声明提升(hoisting)
查看>>
有价值的数据
查看>>
LayUi超级好用的前端工具
查看>>
[Ubuntu] ubuntu的tty下挂载移动硬盘拷贝数据
查看>>
PowerBI分析个人Exchange邮箱数据
查看>>
犯了个低级错误
查看>>
Win7部署基础知识(7):使用Imagex捕获和安装映像
查看>>
Outlook Anywhere 客户端配置详解
查看>>
IOS在Xcode 4.x以上如何 创建 和 添加 静态库
查看>>