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

gangganghao 2004-07-26 04:26:27
如题。。
...全文
221 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')
net的最近面试经典试题ASP.NET面试题集合 1. 简述 private、 protected、 public、 internal 修饰符的访问权限。 答 . private : 私有成员, 在类的内部才可以访问。 protected : 保护成员,该类内部和继承类中可以访问。 public : 公共成员,完全公开,没有访问限制。 internal: 在同一命名空间内可以访问。 2 .列举ASP.NET 页面之间传递值的几种方式。 答. 1.使用QueryString, 如....?id=1; response. Redirect().... 2.使用Session变量 3.使用Server.Transfer 3. 一列数的规则如下: 1、1、2、3、5、8、13、21、34...... 求第30位数是多少, 用递归算法实现。 答:public class MainClass { public static void Main() { Console.WriteLine(Foo(30)); } public static int Foo(int i) { if (i 0 && i <= 2) return 1; else return Foo(i -1) + Foo(i - 2); } } 4.C#中的委托是什么?事件是不是一种委托? 答 : 委托可以把一个方法作为参数代入另一个方法。 委托可以理解为指向一个函数的引用。 是,是一种特殊的委托 5.override与重载的区别 答 : override 与重载的区别。重载是方法的名称相同。参数或参数类型不同,进行多次重载以适应不同的需要 Override 是进行基类中函数的重写。为了适应需要。 6.如果在一个B/S结构的系统中需要传递变量值,但是又不能使用Session、Cookie、Application,您有几种方法进行处理? 答 : this.Server.Transfer 7.请编程遍历页面上所有TextBox控件并给它赋值为string.Empty? 答: foreach (System.Windows.Forms.Control control in this.Controls) { if (control is System.Windows.Forms.TextBox) { System.Windows.Forms.TextBox tb = (System.Windows.Forms.TextBox)control ; tb.Text = String.Empty ; } } 8.请编程实现一个冒泡排序算法? 答: int [] array = new int ; int temp = 0 ; for (int i = 0 ; i < array.Length - 1 ; i++) { for (int j = i + 1 ; j < array.Length ; j++) { if (array[j] < array) { temp = array ; array = array[j] ; array[j] = temp ; } } } 9.描述一下C#中索引器的实现过程,是否只能根据数字进行索引? 答:不是。可以用任意类型。 10.求以下表达式的值,写出您想到的一种或几种实现方法: 1-2+3-4+……+m [Page] 答: int Num = this.TextBox1.Text.ToString() ; int Sum = 0 ; for (int i = 0 ; i < Num + 1 ; i++) { if((i%2) == 1) { Sum += i ; } else { Sum = Sum - I ; } } System.Console.WriteLine(Sum.ToString()); System.Console.ReadLine() ; 11.用.net做B/S结构的系统,您是用几层结构来开发,每一层之间的关系以及为什么要这样分层? 答:一般为3层 数据访问层,业务层,表示层。 数据访问层对数据库进行增删查改。 业务层一般分为二层,业务表观层实现与表示层的沟通,业务规则层实现用户密码的安全等。 表示层为了与用户交互例如用户添加表单。 优点: 分工明确,条理清晰,易于调试,而且具有可扩展性。 缺点: 增加成本。 12.在下面的例子里 using Sy

34,871

社区成员

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

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