C# and ms sql存储过程问问题

mengyao 2007-01-10 05:22:04
//string StfId = Request.QueryString.GetValues("StfId").GetValue(0).ToString();
//string QbNumber = Request.QueryString.GetValues("QbNumber").GetValue(0).ToString();
//string Money = Request.QueryString.GetValues("Money").GetValue(0).ToString();
//以上为取值,现在测试直接用
string StfId = "12";
string QbNumber = "2222222";
string Money = "5";

SqlConnection Conn = new SqlConnection(System.Configuration.ConfigurationSettings.AppSettings.Get("DataConnectionString"));
Conn.Open();


SqlCommand CmdUpdate = new SqlCommand("Pro_QbType", Conn);
CmdUpdate.CommandType = CommandType.StoredProcedure;
CmdUpdate.Parameters.Add("@StfId", SqlDbType.VarChar,4).Value = StfId;
CmdUpdate.Parameters.Add("@QBValues",SqlDbType.VarChar,4).Value = Money;



//建立并添加和“@QBcode OUTPUT”对应的参数
SqlParameter parmReturnValue = new SqlParameter("@QBcode", SqlDbType.VarChar,20);
//parmReturnValue.IsNullable = true;
parmReturnValue.Direction = ParameterDirection.Output;
CmdUpdate.Parameters.Add(parmReturnValue);

CmdUpdate.ExecuteNonQuery();
QBcode = CmdUpdate.Parameters["@QBcode"].Value.ToString();

SqlTransaction Trans = Conn.BeginTransaction();
try
{
CmdUpdate.Transaction = Trans;
CmdUpdate.ExecuteNonQuery();
QBcode =CmdUpdate.Parameters["@QBcode"].Value.ToString();
Trans.Commit();
CmdUpdate.Dispose();
Conn.Close();
}
catch (Exception Err)
{

Response.Write(Err.Message);

}
说明:
在MS SQL2005中执行有返回值,在程序中测试就是为空?
...全文
284 13 打赏 收藏 转发到动态 举报
写回复
用AI写文章
13 条回复
切换为时间正序
请发表友善的回复…
发表回复
xyq1986 2007-01-11
  • 打赏
  • 举报
回复
存储过程帖出来看一下
mengyao 2007-01-11
  • 打赏
  • 举报
回复
换了还是没有用?
xyq1986 2007-01-11
  • 打赏
  • 举报
回复
确定没发生异常之类的?
把CmdUpdate.Parameters.Add("@StfId", SqlDbType.VarChar,4).Value = StfId;
中字符串的长度换大点
mengyao 2007-01-11
  • 打赏
  • 举报
回复
string QBcode = "";
//string StfId = Request.QueryString.GetValues("StfId").GetValue(0).ToString();
//string QbNumber = Request.QueryString.GetValues("QbNumber").GetValue(0).ToString();
//string Money = Request.QueryString.GetValues("Money").GetValue(0).ToString();

//测试用
string StfId = "12";
string QbNumber = "24251880";
string Money = "5";

SqlConnection Conn = new SqlConnection(System.Configuration.ConfigurationSettings.AppSettings.Get("DataConnectionString"));
Conn.Open();


SqlCommand CmdUpdate = new SqlCommand("Pro_QbType", Conn);
CmdUpdate.CommandType = CommandType.StoredProcedure;
CmdUpdate.Parameters.Add("@StfId", SqlDbType.VarChar,4).Value = StfId;
CmdUpdate.Parameters.Add("@QBValues",SqlDbType.VarChar,4).Value = Money;



//建立并添加和“@QBcode OUTPUT”对应的参数
SqlParameter parmReturnValue = new SqlParameter("@QBcode", SqlDbType.VarChar,20);
//parmReturnValue.IsNullable = true;
parmReturnValue.Direction = ParameterDirection.Output;
CmdUpdate.Parameters.Add(parmReturnValue);

//A 直接执行

//CmdUpdate.ExecuteNonQuery();
//QBcode = CmdUpdate.Parameters["@QBcode"].Value.ToString();
//Response.Write(QBcode);

//B 事务方式
SqlTransaction Trans = Conn.BeginTransaction();
try
{
CmdUpdate.Transaction = Trans;
CmdUpdate.ExecuteNonQuery();
Trans.Commit();
//QBcode = CmdUpdate.Parameters["@QBcode"].Value.ToString();
QBcode = Convert.ToString(CmdUpdate.Parameters["@QBcode"].Value);
Response.Write(QBcode);
CmdUpdate.Dispose();
Conn.Close();
}
catch (Exception Err)
{
Response.Write(Err.Message);
}
就这样,顺序哪有问题啊?
xyq1986 2007-01-11
  • 打赏
  • 举报
回复
debug一下,看有没有抛出异常
whb147 2007-01-11
  • 打赏
  • 举报
回复
一定是顺序有问题
mengyao 2007-01-11
  • 打赏
  • 举报
回复
楼上,我把多一次的执行也取消了,顺序也换了,还不行
不用事务,也是不行,真得不解!
mengyao 2007-01-11
  • 打赏
  • 举报
回复
谢谢两位,原来是我搞了一个超级错误,数据库链接是服务器上的,那上边确是只有空状态了,而我一直在本地的SQL上执行,郁闷的很!
mengyao 2007-01-11
  • 打赏
  • 举报
回复
CREATE PROCEDURE [dbo].[Pro_QbType]
@StfId varchar(10),
@QBValues varchar(4),
@QBCode varchar(20) output

AS
IF @QBValues =5
begin
select top 1 @QBCode=QBCode from QB5 where QBFlag like '0'
update QB5 set QBFlag='5',StfId=@StfId,OutTime=getdate() where QBCode=@QBCode
select QBcode from QB5 where QBcode=@QBcode
end
else if @QBValues =10
begin
select top 1 @QBCode=QBCode from QB10 where QBFlag like '0'
update QB10 set QBFlag='5',StfId=@StfId,OutTime=getdate() where QBCode=@QBCode
select QBcode from QB10 where QBcode=@QBcode
end
else if @QBValues =20
begin
select top 1 @QBCode=QBCode from QB20 where QBFlag like '0'
update QB20 set QBFlag='5',StfId=@StfId,OutTime=getdate() where QBCode=@QBCode
select QBcode from QB20 where QBcode=@QBcode
end
else
begin
select top 1 @QBCode=QBCode from QB where QBFlag like '0'
update QB set QBFlag='5',StfId=@StfId,OutTime=getdate() where QBCode=@QBCode
select QBcode from QB where QBcode=@QBcode
end
xyq1986 2007-01-10
  • 打赏
  • 举报
回复
QBcode =CmdUpdate.Parameters["@QBcode"].Value.ToString();
Trans.Commit();
这两句的顺序换一下,先提交事务,再取数据
xyq1986 2007-01-10
  • 打赏
  • 举报
回复
CmdUpdate.ExecuteNonQuery();怎么执行了两次
mengyao 2007-01-10
  • 打赏
  • 举报
回复
同样的效果,还有什么地方可以注意啊?
leohuang 2007-01-10
  • 打赏
  • 举报
回复
试试
QBcode =CmdUpdate.Parameters[2].Value.ToString();
提供的源码资源涵盖了Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用欢迎随时与博主沟通,第一时间进行解答!
提供的源码资源涵盖了小程序应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用欢迎随时与博主沟通,第一时间进行解答!

110,539

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

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