存储过程中新建临时表的

要写一个存储过程,如果临时表 test 不存在 ,新建临时表,如果存在不新建

 

alter procedure test
as
    if object_id('tempdb..#test') is null
        begin
            print '不存在'
            create table #test (
                number int not null primary key,
                message varchar(50) not null
            )
        end
else
    print '存在'

 

exec test
select * from #test

上面的SQL语句,调用存储过程之后查询临时表会报错

不存在
消息 2714,级别 16,状态 6,过程 test,第 6 行
数据库中已存在名为 '##test' 的对象。

后来将 #test 改为 ##test  便可以了

猜想可能是在存储过程中创建的 #test 只能在存储过程中写查询可以查询到 ##表示全局临时表,在存储过程外也可以查询到

 

转载于:https://www.cnblogs.com/privategardens/p/10772984.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值