haitao:
想把一个比较复杂的被执行的sql字符串里的中间结果截取出来,给执行者再处理。。。。。。
[阅读: 915] 2007-08-16 06:35:45
——相当于 截取存储过程的返回记录集 再做处理。。。。。。。。
比如这个sql是很正常的:
declare @tb table(fid int IDENTITY,fname varchar(50),fdatetime datetime)
insert @tb (fname,fdatetime) values ('aaaa',getdate())
insert @tb (fname,fdatetime) values ('bbbb',getdate())
insert @tb (fname,fdatetime) values ('cccc',getdate())
select * from @tb
把它包在字符串里执行也很正常:
declare @sql nvarchar(4000)
set @sql=
'
declare @tb table(fid int IDENTITY,fname varchar(50),fdatetime datetime)
insert @tb (fname,fdatetime) values (''aaaa'',getdate())
insert @tb (fname,fdatetime) values (''bbbb'',getdate())
insert @tb (fname,fdatetime) values (''cccc'',getdate())
select * from @tb
'
exec sp_executesql @sql
如果想把被执行的字符串里的@tb的结果直接放到执行者的@tb2里呢?
declare @sql nvarchar(4000)
declare @tb2 table(fid int IDENTITY,fname varchar(50),fdatetime datetime)
set @sql=
'
--declare @tb table(fid int IDENTITY,fname varchar(50),fdatetime datetime)
insert @tb (fname,fdatetime) values (''aaaa'',getdate())
insert @tb (fname,fdatetime) values (''bbbb'',getdate())
insert @tb (fname,fdatetime) values (''cccc'',getdate())
--select * from @tb
'
exec sp_executesql @sql, N'@tb table(fid int IDENTITY,fname varchar(50),fdatetime datetime) output',@tb=@tb2 output
select * from @tb2
——好像不支持了!!!