请问高手,怎样调用存储过程返回数据集?急啊!!!

tob 2003-07-30 02:05:59
在oracle建立了一个包,包里有一个test1的存储过程,怎么用asp.net(c#)调用存储过程返回数据集,并写到datagrid里?
create or replace package Test1 is
type rs is ref cursor;
PROCEDURE getYhRs(ydm in varchar, yhrs out rs);
end Test1;

create or replace package body Test1 is

PROCEDURE getYhRs(ydm in varchar, yhrs out rs) as

begin
open yhrs for select * from t_yonghu WHERE yhdm=ydm;
end;
end Test1;
...全文
29 8 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
tob 2003-07-30
  • 打赏
  • 举报
回复
谢谢大家!但好像都不行,我的存储过程写在包里,而且要返回数据集
liuzhonghe 2003-07-30
  • 打赏
  • 举报
回复
看一下SDK的SqlCommand类,关于它的用法里面的有详细的例子。
xu0007 2003-07-30
  • 打赏
  • 举报
回复
sql 的
storedProcName:存储过程名称 parameters:参数集 tableName:返回的表名
public DataSet RunProcedure(string storedProcName, IDataParameter[] parameters, string tableName )
{
DataSet dataSet = new DataSet();
SqlDataAdapter sqlDA = new SqlDataAdapter();
sqlDA.SelectCommand = BuildQueryCommand( storedProcName, parameters );
sqlDA.Fill( dataSet, tableName );
return dataSet;
}
greystar 2003-07-30
  • 打赏
  • 举报
回复
public DataSet ExeForSp(string sqname, string [,] array )
{
try
{
DataSet dset =new DataSet();
SqlDataAdapter dp=new SqlDataAdapter();


SqlCommand cmmd = new SqlCommand();
dp.SelectCommand=cmmd;
dp.SelectCommand.Connection =this.conn;
dp.SelectCommand.CommandType=CommandType.StoredProcedure;
dp.SelectCommand.CommandText =sqname;
for(int i=0;i<=array.GetUpperBound(0);i++)
{

if(array[i,0]!=null)
{
SqlParameter Parm = dp.SelectCommand.Parameters.Add( array[i,0].ToString(), SqlDbType.NVarChar);
Parm.Value =array[i,1].ToString();
}
}
dp.Fill(dset);
return dset;
}
catch(System.Exception e)
{
throw e;
}
}
yohomonkey 2003-07-30
  • 打赏
  • 举报
回复
有Sql的:
Public Function RunStoreProcReturn(ByVal sStoreProduceName As String, Optional ByRef colParms As Collection = Nothing) As DataSet
StrSqlConn = New SqlConnection(STRCONN)
Dim ds As New DataSet()
Dim sqlAdapt As New SqlDataAdapter()
Dim sqlCMD As New SqlCommand(sStoreProduceName, StrSqlConn)
sqlCMD.CommandType = CommandType.StoredProcedure
If Not IsNothing(colParms) Then
Dim oParm As SqlClient.SqlParameter
For Each oParm In colParms
sqlCMD.Parameters.Add(oParm)
Next
End If

Try
StrSqlConn.Open()
sqlAdapt.SelectCommand = sqlCMD
sqlAdapt.Fill(ds)
Return ds
Catch e As Exception

Finally
StrSqlConn.Close()
End Try
End Function
fbysss 2003-07-30
  • 打赏
  • 举报
回复
在帮助中找游标类型,你可以自定义一个游标类型的函数。
能够通过Ado控件返回数据集.
很久没用ORACLE了。例子我以前写了一个,我找找,如果找到了给你。
tob 2003-07-30
  • 打赏
  • 举报
回复
大家有例子吗?谢了!!
nchln 2003-07-30
  • 打赏
  • 举报
回复
我知道用DataSet可以直接获取数据集,没有做过asp.net的相关内容,搂主可以试试
在Windows 10或Windows 11操作系统中,用户经常会遇到共享打印机时出现的一系列错误代码,这些错误代码可能会阻碍打印机共享功能的正常使用。常见的错误代码包括0x00000057、0x00000709和0x0000011b,这些代码通常指出了不同的问题,比如权限不足、服务未运行或配置错误等。除此之外,还有一些故障提示如“连接失败”或“内存不足”,这些都可能影响到打印机共享的稳定性。 要解决这些故障,首先要确保打印机已经正确地连接到网络,并且在需要共享的电脑上进行了设置。确保打印机驱动程序是最新的,并且在共享设置中没有错误配置。对于权限问题,需要检查网络上的用户账户是否具有足够的权限来访问共享打印机。同时,也要确保打印机服务正在运行,特别是“Print Spooler”服务,因为这是打印机共享服务的核心组件。 在某些情况下,问题可能与操作系统的更新有关,如升级到最新版的Windows 10或Windows 11后可能出现的兼容性问题。这时,可能需要查看微软的官方支持文档来获取特定的解决方案或更新。 对于错误代码0x00000057,这通常是由于没有足够的权限来访问网络打印机或其共享资源,解决方法是确保网络打印机的权限设置正确,包括在组策略中设置相应的访问权限。而0x00000709错误可能是由于打印机驱动问题或打印机端口配置错误,可以尝试重新安装或更新打印机驱动来解决。至于0x0000011b错误,这往往是因为打印机队列服务的问题,检查并重启“Print Spooler”服务通常是解决这类问题的常见手段。 至于“连接失败”或“内存不足”这类故障,通常与客户端和打印机之间的网络连接以及打印机本地资源的使用情况有关。检查网络连接,确保打印机所在的网络段没有故障或中断。同时,如果打印机的打印队列长时间得不到处理,可能会导致内存不足的情况,这时可能需要清理打印队列或增加打印机的内存配置。 为了帮助用户更快速地解决这些问题,市面上出现了各种打印机共享错误修复工具。这些工具往往通过预设的修复程序来自动检测和修正打印机共享中常见的问题。它们可以快速检查打印机驱动、网络连接以及共享设置,并且能够提供一键修复功能,大幅减少了用户自行排查和解决问题的难度。 然而,在使用这些修复工具之前,用户应确保这些工具的来源是安全可靠的,避免因使用不当的修复工具而引发其他系统安全或隐私问题。用户可以到官方平台或者信誉良好的软件提供商处下载这些工具。通过细心检查打印机的共享设置,及时更新驱动程序和服务,以及合理使用修复工具,大多数共享打印机的问题都可以得到有效的解决。

62,244

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

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