| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 459 人关注过本帖
标题:如何用ASP.net向数据库添加存储过程???
只看楼主 加入收藏
ft4029928
Rank: 1
等 级:新手上路
帖 子:94
专家分:0
注 册:2008-12-14
结帖率:81.82%
收藏
已结贴  问题点数:20 回复次数:2 
如何用ASP.net向数据库添加存储过程???
我开发还原数据库,需要建立一个存储过程来关闭用户的连接,但是失败了,代码如下。我在数据库里面直接操作是可以的,但是用C#代码实现就错误了,但不知道错误在哪里?请问各位高手。谢谢各位了。

提示的错误如下:

传入的表格格式数据流(TDS)远程过程调用(RPC)协议流不正确。RPC 名无效。

说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。

异常详细信息: System.Data.SqlClient.SqlException: 传入的表格格式数据流(TDS)远程过程调用(RPC)协议流不正确。RPC 名无效。

源错误:


行 95:             = CommandType.StoredProcedure;
行 96:             myConnection.Open();
行 97:             myCommand.ExecuteNonQuery();
行 98:             myConnection.Close();
行 99:

程序代码:
string str = @"use master
                           go
                           if exists (select * from master.dbo.sysobjects where name = 'killspid' and xtype = 'p')
                           DROP PROCEDURE killspid
                           go
                           create proc killspid (@dbname varchar(20))
                           as
                           begin
                           declare @sql nvarchar(500)
                           declare @spid int
                           set @sql='declare getspid cursor for 
                           select spid from sysprocesses where dbid=db_id('''+@dbname+''')'
                           exec (@sql)
                           open getspid
                           fetch next from getspid into @spid
                           while @@fetch_status<>-1
                           begin
                           exec('kill '+@spid)
                           fetch next from getspid into @spid
                           end
                           close getspid
                           deallocate getspid
                           end
                           go";
SqlConnection myConnection = new SqlConnection("server=" + server + ";uid=" + uid + ";pwd=" + pwd + ";database=master");
            SqlCommand myCommand = myConnection.CreateCommand();
             = sql;
             = CommandType.StoredProcedure;
            myConnection.Open();
            myCommand.ExecuteNonQuery();
            myConnection.Close();


[ 本帖最后由 ft4029928 于 2012-5-27 16:56 编辑 ]
搜索更多相关主题的帖子: 数据库 详细信息 数据流 如何 
2012-05-27 16:52
yms123
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:209
帖 子:12488
专家分:19042
注 册:2004-7-17
收藏
得分:14 
= CommandType.StoredProcedure;//这句话欠妥,因为你没有添加存储过程,这里command为存储过程只有在执行时才能这么写,可以尝试把这个改为sql语句试试看
2012-05-28 09:48
ft4029928
Rank: 1
等 级:新手上路
帖 子:94
专家分:0
注 册:2008-12-14
收藏
得分:0 
回复 2楼 yms123
已经解决了,但问题主要不是出在这里,在写的那句SQL语句,你说的是其中一个原因,谢谢了!


2012-06-02 12:54
快速回复:如何用ASP.net向数据库添加存储过程???
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.025796 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved