怎样判读一个存储过程是否返回的是记录集,如果是,则列出记录集中的所有字段。

gangganghao 2004-07-26 04:26:27
如题。。
...全文
218 10 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
gangganghao 2004-07-27
  • 打赏
  • 举报
回复
OK..再去程序区问一问。。
zjcxc 元老 2004-07-26
  • 打赏
  • 举报
回复
我想这个问题在程序中去解决比较好一点. 在SQL中好像有点难做到.
zjcxc 元老 2004-07-26
  • 打赏
  • 举报
回复
wanyingsong(豌豆) 的方法还存在一个问题,如果我的存储过程是这样的:

create proc test
as
select 1 --虽然返回的是结果集,但没有指定列名,一样会出错.
zjcxc 元老 2004-07-26
  • 打赏
  • 举报
回复
wanyingsong(豌豆) 的,如果存储过程不是返回表集,会报错.


对于有输入参数的存储过程,当然要输入参数进行模拟来获得数据集的查询结果.
因为有的存储过程在输入不同参数时,有可能是结果集,也可能是返回值,所以必须输入参数确定
gangganghao 2004-07-26
  • 打赏
  • 举报
回复
to:wanyingsong(豌豆)

如果存储过程有输入参数,是不是需要首先获取输入参数信息,再对输入参数进行模拟来获得数据集的查询结果?
gangganghao 2004-07-26
  • 打赏
  • 举报
回复
研究一下。。

谢谢。。
老宛 2004-07-26
  • 打赏
  • 举报
回复
--判断是否有结果,如果有的话列出所有字段,待优化

IF EXISTS(SELECT name
FROM sysobjects
WHERE name = N'testtable'
AND type = 'U')
DROP TABLE testtable
GO
if exists(SELECT *
FROM OPENROWSET('SQLOLEDB',
'DRIVER={SQL Server};SERVER=server;UID=sa;PWD=',
'exec ft_xs..bbb') AS a)
begin
SELECT * into testtable
FROM OPENROWSET('SQLOLEDB',
'DRIVER={SQL Server};SERVER=server;UID=sa;PWD=',
'exec ft_xs..bbb') AS a

exec sp_columns 'testtable'
end
viptiger 2004-07-26
  • 打赏
  • 举报
回复
select * from syscolumns
where isoutparam = 1
and id in (select [id] from objects
where [name] = 'you procedure' and xtype = 'p')

if @@rowcount <> 0
begin
print '有返回值'
end
老宛 2004-07-26
  • 打赏
  • 举报
回复
SELECT *
FROM OPENROWSET('SQLOLEDB',
'DRIVER={SQL Server};SERVER=ServerName;UID=sa;PWD=',
'exec DBName..ProcName') AS a

viptiger 2004-07-26
  • 打赏
  • 举报
回复
select id from syscolumns where isoutparam = 1


(select [id] from objects where [name] = 'you procedure' and xtype = 'p')

34,837

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧