ADO.Net(C#)中怎么执行Oracle的存储过程
创建一个Oracle的存储过程,能完成根据id来查询,并在ADO.Net中获取它所返回的值,比如:表table1中有id,name,age,sex,email字段,然后我...
创建一个Oracle的存储过程,能完成根据id来查询,并在ADO.Net中获取它所返回的值,比如:表table1中有id,name,age,sex,email 字段,然后我要根据所传入存储过程的id来查出这些值,就像(select * from table where id = 所传入的值),这样的类型。求高手指点,谢谢。
展开
2个回答
展开全部
SqlConnection conn=new SqlConnection ();
SqlCommand cmd = conn.CreateCommand();
cmd.CommandType = CommandType.StoredProcedure; //命令类型是存储过程
cmd.CommandText = "存储过程的名字";
SqlCommand cmd = conn.CreateCommand();
cmd.CommandType = CommandType.StoredProcedure; //命令类型是存储过程
cmd.CommandText = "存储过程的名字";
追问
是Oracle的,尤其是建立Oracle的存储过程,应为有返回集,所以不知道怎么弄了,还有怎么获取返回集,继续等高手指导,完成后加分。
展开全部
这种问题我早就碰过了,使用多线程是一种非常不好的选择,你的系统随时都会崩溃。
办法其实非常简单,你只要使用ADO异步操作就可以了,完全不必建立多线程,当然这涉及ADO的高级应用,今天心情好,教你几招!(下面是我在VB中使用过的方法,DELPHI中同样也能使用ADO异步操作访问SQLSERVER)
之前先与SQL SERVER建立一个CONNECTION对象,将其CURSORLOCATION属性设置为adUseClient 然后用ADO CONNECTION的Execute方法异步执行存储过程即可
例如:con.CursorLocation = adUseClient
dim strSQL as String
strSQL="SQL语句或存储过程名及其参数" '语法必须正确
con.Execute strSQL, , adAsyncExecute 'adAsyncExecute指令异步操作
这样你的应用程序就不用等待存储过程执行完毕后才可执行后续代码了。
你还可以使用ADO CONNECTION对象的ExecuteComplete事件在执行完存储过程后
通知你的应用程序执行相应的动作,例如MSGBOX等之类的东西,具体的实现代码你自己去查ADO联机手册。
另外顺便提一下,如果对于一个执行了很长时间都未能完成的查询,你别指望使用貌似很行的ADO的CANCEL方法,立即取消一个正在执行的ADO异步操作,即使在更新版本的ADO.net 3.5也是如此(非要等到超时后才能生效),真不明白微软的工程师们是如何想的!谁要是能给出解决方法,我奖他300分,外加现金若干。
答复补充问题:
“四楼的大哥 我还想问一下 如果我在这个存储过程还没有执行完成的时候 其他客户端又调用了这个存储过程 会不会出错呢???我不太清楚一个存储过程还没有执行完的时候 是否可以再次调用 请指教 谢谢!!!!”
不会的,因为SQLSERVER引擎会处理这些并发问题(自动使用事务处理,微软的工程师们早就想到这些问题了,请放心使用)
追问
、、、copy 也不能这么搞啊,继续等高手解答。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询