标题:1个关于 表变量与拼SQL语句 的问题
只看楼主
averting
Rank: 1
等 级:新手上路
帖 子:12
专家分:0
注 册:2006-6-9
 问题点数:0 回复次数:7 
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
LouisXIV
Rank: 6Rank: 6
等 级:贵宾
威 望:25
帖 子:789
专家分:0
注 册:2006-1-5
得分:0 

EXEC语句的运行环境和外部的语句不同,在外部定义的变量不可在exec内部使用

同样的,内部定义的变量也不可以在外部使用


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

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

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

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

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


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


2006-07-18 12:10
LouisXIV
Rank: 6Rank: 6
等 级:贵宾
威 望:25
帖 子:789
专家分:0
注 册:2006-1-5
得分:0 
你试试##temp

2006-07-18 12:18
LouisXIV
Rank: 6Rank: 6
等 级:贵宾
威 望:25
帖 子:789
专家分:0
注 册:2006-1-5
得分:0 
你写函数当然也可以

2006-07-18 12:18
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
LouisXIV
Rank: 6Rank: 6
等 级:贵宾
威 望:25
帖 子:789
专家分:0
注 册:2006-1-5
得分:0 
##是全局临时表,当创建连接没有中断之前,所有连接都可以使用

#是局部临时表,仅创建连接可以看到并使用

与之类似的还有@@开始的全局变量和@开始的局部变量(MSSQL中,用户只能定义局部变量,全局变量只有系统保留的几个)

函数你可以翻翻看历史帖子,以前有人发过一个

2006-07-18 13:21



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




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

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