| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1069 人关注过本帖
标题:关于调用存储过程返回值的不解
只看楼主 加入收藏
tokoyoshi
Rank: 2
等 级:论坛游民
帖 子:99
专家分:67
注 册:2009-10-24
结帖率:87.1%
收藏
 问题点数:0 回复次数:4 
关于调用存储过程返回值的不解
  public int RunProcedure(string storedProcName, IDataParameter[] parameters, out int rowsAffected)
        {
            int count;
            conn.Open();
            SqlCommand cmd=BuildCommand(storedProcName, parameters);//此方法用来添加参数,存储过程名,返回cmd
            rowsAffected=cmd.ExecuteNonQuery();//参数1
            count=(int)cmd.Parameters["ReturnValue"].Value;//参数2
            conn.Close();

            return count;
        }

参数1会准确的反应执行存储过程所影响的行数,但是返回的参数即使操作成功也返回0,是不是和我的存储过程中没有返回值有关,这里的 returnvalue,是不是指,你在写存储过程时生命的OUTPUT,关于参数的对应,请高手给个明确的解释,我这样想对吗
搜索更多相关主题的帖子: 返回值 
2009-10-26 16:30
domon
Rank: 3Rank: 3
来 自:河南
等 级:论坛游侠
帖 子:92
专家分:191
注 册:2009-10-26
收藏
得分:0 
count=(int)cmd.Parameters["ReturnValue"].Value;
这个一般是存储过程中用return 返回的参数,如:  
 
...  
...  
..  
--过程体  
 
return 0

rowsAffected=cmd.ExecuteNonQuery();
这个是执行影响的行数,但你说的返回0,我也不确定是什么原因
个人估计是因为你两个参数返回的时候混淆了
下班回家了

希望,是走出来的!!!
2009-10-26 16:56
tokoyoshi
Rank: 2
等 级:论坛游民
帖 子:99
专家分:67
注 册:2009-10-24
收藏
得分:0 
知道错在哪了,ouput设置默认值,要set  =@@rowcount,才能获得影响行数,大家切记切记······
2009-10-26 18:05
tokoyoshi
Rank: 2
等 级:论坛游民
帖 子:99
专家分:67
注 册:2009-10-24
收藏
得分:0 
你真是我的福星·····以后我发帖你直接洒点水就行,看见你我就有灵感······
2009-10-26 18:06
domon
Rank: 3Rank: 3
来 自:河南
等 级:论坛游侠
帖 子:92
专家分:191
注 册:2009-10-26
收藏
得分:0 
嘎嘎,那你以后发帖记得提醒我下

希望,是走出来的!!!
2009-10-26 19:34
快速回复:关于调用存储过程返回值的不解
数据加载中...
 
   



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

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