| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1136 人关注过本帖
标题: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
快速回复:1个关于 表变量与拼SQL语句 的问题
数据加载中...
 
   



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

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