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>");
}

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

谢谢大家了
...全文
117 9 打赏 收藏 转发到动态 举报
AI 作业
写回复
用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
Visual Studio Code 是由微软开发的一款免费、开源、跨平台的现代化轻量级代码编辑器,自发布以来迅速成为全球开发者最受欢迎的工具之一。它结合了编辑器的轻便性和集成开发环境(IDE)的强大功能,支持多种编程语言和开发场景,核心特点: 1. 跨平台支持 可在 Windows、macOS 和 Linux 上运行,保持一致的用户体验。 2. 轻量级与高性能 启动速度快,占用资源少,适合处理大型项目或低配置设备。 3. 智能代码补全 内置 IntelliSense(智能感知),提供代码提示、参数信息、快速修复等功能,支持 JavaScript、TypeScript、Python、C++ 等主流语言。 4. 内置终端 直接在编辑器内打开集成终端(支持 PowerShell、CMD、Bash 等),方便执行命令行操作。 5. 调试工具 内置调试器,支持断点、变量监视、调用堆栈查看等,无需离开编辑器即可调试代码。 6. Git 集成 直接通过侧边栏管理 Git 仓库,支持提交、分支切换、冲突解决等操作。 7. 丰富的扩展生态系统 通过 Extensions Marketplace 可安装数千款插件,扩展功能包括: 语言支持:如 Java、Go、Rust 等。 主题与图标:自定义界面风格。 工具集成:如 Docker、Kubernetes、数据库连接等。 效率工具:如 REST Client、Live Server 等。 8. 自定义与主题 支持修改键盘快捷键、界面主题、文件图标等,打造个性化开发环境。 9. 多光标编辑 按住 Alt(Windows/Linux)或 Option(macOS)点击可添加多个光标,同编辑多处代码。 10. 远程开发支持 通过 Remote - SSH、Remote - Containers 等扩展,可直接连接远程服务器或开发容器,实现无缝协作。

62,243

社区成员

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

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

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

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