SQL 2000中执行SQL语句时,产生错误,怎样获取显示在WEB页面, 而不让SQL的错误信息直接显示在WEB页面.

netspies 2008-06-12 01:12:44
比如存储过程:
CREATE PROCEDURE Sp_B_Check_Control
(
@Checkresult INT OUT ,
@djbh VARCHAR(20)
)

AS

SET NOCOUNT ON
SET XACT_ABORT ON
BEGIN TRAN

update T set X = 1000 , y = 800 where djbh = @djbh ;
IF(@@error <> 0 )
BEGIN
Rollback;
SET @Checkresult = -1 ;
RETURN ;
END

SET @Checkresult = 1 /*====成功返回1======*/
COMMIT TRAN;

说明: 上面的T表中,我设置了一个约束 X > Y , 所以这样会出错,为了做实验.

===============================================================================

下面是ASPX.CS文件调用语句:

SQLHelper sqlHelper = new SQLHelper();
SqlParameter[] paramList = {
sqlHelper.CreateOutParam("@Checkresult",SqlDbType.Int,8),
sqlHelper.CreateInParam("@djbh ",SqlDbType.VarChar,20,djbh)
};
sqlHelper.RunProc("Sp_B_Check_Control", paramList);
i_opersult = Convert.ToInt16(paramList[0].Value);

if (i_opersult == 1)
{

Page.RegisterStartupScript("1", "<script>alert('表单成功!')</script>");
}
else
{
Page.RegisterStartupScript("1", "<script>alert('表单失败!!!')</script>");
}

////但是执行这个后,会出现系统错误,我怎么样来屏蔽,来显示我的提示信息.
系统不是按我的思路来的

谢谢大家了
...全文
127 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
netspies 2008-06-12
  • 打赏
  • 举报
回复
大家的思想好象都差不多

在数据库里rollback之后用raiserror抛出异常,然后再客户端try{}catch{}来捕捉
这个我不会用,不过还是谢谢了!
zlkingdom 2008-06-12
  • 打赏
  • 举报
回复
其实你只要在webconfig中设置一下,将debug设置为false,别人在远程打开网页时就看不到错误了
sunchaohuang 2008-06-12
  • 打赏
  • 举报
回复
try
{
SQLHelper sqlHelper = new SQLHelper();
SqlParameter[] paramList = {
sqlHelper.CreateOutParam("@Checkresult",SqlDbType.Int,8),
sqlHelper.CreateInParam("@djbh ",SqlDbType.VarChar,20,djbh)
};
sqlHelper.RunProc("Sp_B_Check_Control", paramList);
i_opersult = Convert.ToInt16(paramList[0].Value);
Page.RegisterStartupScript("1", " <script>alert('表单成功!') </script>");
}
catch (Exception ee)
{
Page.RegisterStartupScript("1", " <script>alert('表单失败!!!') </script>");
return;
}
finally
{
//在这里关闭连接
}
大自然D使者 2008-06-12
  • 打赏
  • 举报
回复
这种情况可以用try{}catch{}来实现嘛。
zengxie 2008-06-12
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 jinjazz 的回复:]
在数据库里rollback之后用raiserror抛出异常,然后再客户端try{}catch{}来捕捉
[/Quote]
jacklau88 2008-06-12
  • 打赏
  • 举报
回复
try
{
SQLHelper sqlHelper = new SQLHelper();
SqlParameter[] paramList = {
sqlHelper.CreateOutParam("@Checkresult",SqlDbType.Int,8),
sqlHelper.CreateInParam("@djbh ",SqlDbType.VarChar,20,djbh)
};
sqlHelper.RunProc("Sp_B_Check_Control", paramList);
i_opersult = Convert.ToInt16(paramList[0].Value);

if (i_opersult == 1)
{

Page.RegisterStartupScript("1", " <script>alert('表单成功!') </script>");
}
else
{
Page.RegisterStartupScript("1", " <script>alert('表单失败!!!') </script>");

}
}
catch(SqldbException ex)
{
//抛出异常,可以直接显示在web上,最好是调用自己的保存日志的方法,将系统异常信息保存起来。
如果直接显示在页面上就用下面的
Response.Write(ex.ToSting());
否则
Event(ex.ToSting());

}
jinjazz 2008-06-12
  • 打赏
  • 举报
回复
在数据库里rollback之后用raiserror抛出异常,然后再客户端try{}catch{}来捕捉
wzy_love_sly 2008-06-12
  • 打赏
  • 举报
回复
 try
{
SQLHelper sqlHelper = new SQLHelper();
SqlParameter[] paramList = {
sqlHelper.CreateOutParam("@Checkresult",SqlDbType.Int,8),
sqlHelper.CreateInParam("@djbh ",SqlDbType.VarChar,20,djbh)
};
sqlHelper.RunProc("Sp_B_Check_Control", paramList);
i_opersult = Convert.ToInt16(paramList[0].Value);
Page.RegisterStartupScript("1", " <script>alert('表单成功!') </script>");
}
catch (Exception ee)
{
Page.RegisterStartupScript("1", " <script>alert('表单失败!!!') </script>");
return;
}
wzy_love_sly 2008-06-12
  • 打赏
  • 举报
回复
try catch
【SCI复现】基于纳什博弈的多微网主体电热双层共享策略研究(Matlab代码实现)内容概要:本文围绕“基于纳什博弈的多微网主体电热双层共享策略研究”展开,结合Matlab代码实现,复现了SCI级别的科研成果。研究聚焦于多个微网主体之间的能源共享问题,引入纳什博弈理论构建双层优化模型,上层为各微网间的非合作博弈策略,下层为各微网内部电热联合优化调度,实现能源高效利用与经济性目标的平衡。文详细阐述了模型构建、博弈均衡求解、约束处理及算法实现过程,并通过Matlab编程进行仿真验证,展示了多微网在电热耦合条件下的运行特性和共享效益。; 适合人群:具备一定电力系统、优化理论和博弈论基础知识的研究生、科研人员及从事能源互联网、微电网优化等相关领域的工程师。; 使用场景及目标:① 学习如何将纳什博弈应用于多主体能源系统优化;② 掌握双层优化模型的建模与求解方法;③ 复现SCI论文的仿真案例,提升科研实践能力;④ 为微电网集群协同调度、能源共享机制设计提供技术参考。; 阅读建议:建议读者结合Matlab代码逐行理解模型实现细节,重点关注博弈均衡的求解过程与双层结构的迭代逻辑,同可尝试修改参数或扩展模型以适应不同应用场景,深化对多主体协同优化机制的理解。

62,257

社区成员

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

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

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

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