标题:1个关于 表变量与拼SQL语句 的问题
取消只看楼主
averting
Rank: 1
等 级:新手上路
帖 子:12
专家分:0
注 册:2006-6-9
 问题点数:0 回复次数:3 
1个关于 表变量与拼SQL语句 的问题

一个自己之前没发现的问题

错误写法:
declare @s varchar(200)
Declare @tempTable table
(
定额号 varchar(10)
)
set @s = 'insert into @tempTable values(''' + 'JZ-BC001' + ''')'
exec(@S)
select * from @tempTable

提示 @tempTable 变量不存在


正确写法:
declare @s varchar(200)
set @s = 'Declare @tempTable table(定额号 varchar(10)) '
set @s = @s + 'insert into @tempTable values(''' + 'JZ-BC001' + ''')'
set @s = @s + 'select * from @tempTable'
exec(@S)



declare @t varchar(100)
Declare @tempTable table
(
定额号 varchar(10)
)
set @t = 'JZ-BC001'
insert into @tempTable values(@t)
select * from @tempTable


为啥在前面定义表变量 ,后面拼SQL语句,最后查询表变量就不可用呢!

搜索更多相关主题的帖子: SQL 变量 语句 
2006-07-18 11:36
averting
Rank: 1
等 级:新手上路
帖 子:12
专家分:0
注 册:2006-6-9
得分:0 

现在在做一个自动编号,自动编号的代码写好了,放在存储过程里。

存储过程外面的语句要用到自动编号,于是我就把编号存在变量里。不能够用
自动编号存在#temp临时表里,存储过程外面也不可以用!

存储过程里的自动编号值存在什么哪里才可以让外部使用呢,难道非得创建一个永久性表吗?

有其他什么方法可以封装自动编号代码,让外部语句使用呢?函数?!


不会用,麻烦版主写一段能够让外部使用的代码


2006-07-18 12:10
averting
Rank: 1
等 级:新手上路
帖 子:12
专家分:0
注 册:2006-6-9
得分:0 

没写过函数,请版主写一个供参考

2006-07-18 13:14
averting
Rank: 1
等 级:新手上路
帖 子:12
专家分:0
注 册:2006-6-9
得分:0 
版主,#temp,##temp区别。论团有相关资料吗
太神奇了,什么问题都解决了!
2006-07-18 13:16



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-78960-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.060740 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved