公司网站建设属于软件销售湖南金科建设有限公司网站

news/2025/10/8 15:34:59/文章来源:
公司网站建设属于软件销售,湖南金科建设有限公司网站,网站建设移交确认书,如何做自媒体和网站签约赚点击任何程序都可能出现错误#xff0c;在SQL Server中执行Transact-SQL也不例外。如果在Transact-SQL中发生了错误#xff0c;一般有两种捕捉错误的方法#xff0c;一种是在客户端代码#xff08;如 c#、delphi等)中使用类似try...catch的语句进行捕捉#xff1b;另外一种就是…任何程序都可能出现错误在SQL Server中执行Transact-SQL也不例外。如果在Transact-SQL中发生了错误一般有两种捕捉错误的方法一种是在客户端代码如 c#、delphi等)中使用类似try...catch的语句进行捕捉另外一种就是在Transact-SQL中利用Transact-SQL本身提供的错误捕捉机制进行捕捉。如果是因为Transact-SQL语句的执行而产生的错误如键值冲突使用第一种和第二种方法都可以捕捉但是如果是逻辑错误使用客户端代码进行捕捉就不太方便。因此本文就如何使用Transact-SQL进行错误捕捉进行了讨论。一、非致命错误(non-fatal error)的捕捉    通过执行Transact-SQL而产生的错误可分为两种致命错误(fatal error)和非致命错误(non-fatal error)。在Transact-SQL中只可以捕捉非致命错误(如键值冲突)而无法捕捉致命错误(如语法错误)。在Transact-SQL中可以通过系统变量ERROR判断最近执行的一条语句是否成功执行。如果发生了错误Error的值大于0否则值为0。下面举一个例子说明 ERROR的使用。    假设有一个表table1在这个表中有两个字段f1f2。其中f1是主键。    INSERT INTO table1 VALUES(1, aa)    INSERT INTO table1 VALUES(1, bb)  --这条语句将产生一个错误    IF ERROR  0      PRINT 键值冲突    当执行第二条语句时发生键值冲突错误ERROR被赋为错误号2627因此输出结果显示键值冲突。使用ERROR系统变量时需要注意 ERROR只记录最近一次执行的Transact-SQL语句所发生的错误如果最近一次执行的Transact-SQL没有发生错误 ERROR的值为0。因此只能在被捕捉的那条Transact-SQL语句后使用ERROR。    在SQL Server中不仅可以捕捉系统提供的错误还可以自定义错误。有两种方法可以定义错误信息。    1. 使用sp_addmessage系统存储过程添加错误信息然后使用RAISERROR抛出错误。    sp_addmessage将错误号错误级别、错误描述等信息添加到系统表中然后使用RAISERROR根据相应的错误号抛出错误信息。用户自定义的信息应该从50001开始。   EXEC sp_addmessage msgnum  50001, severity  16,   msgtext  sql encounter an error(%s).,   lang  us_english   EXEC sp_addmessage msgnum  50001, severity  16,   msgtext  sql遇到了一个错误(%1!).   如果使用的SQL Server版本是非英语版本在添加本地错误信息时必须首先添加英文的错误信息。错误描述可以象c语言中的printf的格式字符串一样使用参数如% s、%d。但要注意的是在英文版的错误信息中要使用%s、%d等形式而在本地化的错误信息中要使用%1!、%2!等形式在每个%?(1 ? n)后需要加一个!而且%?的数目必须和英文版的错误信息的参数一致。   在未插入本地化错误信息时RAISERROR将使用英文版的错误信息。当插入本地化错误信息时RAISERROR使用本地化的错误信息。   RAISERROR(50001, 16, 1, 测试)      输出的结果   服务器: 消息 50001级别 16状态 1行 1   sql遇到了一个错误(测试).   其中测试字符串通过%1传入本地化的错误描述字符串中。     2. 直接使用RAISERROR将错误抛出。    使用第一种方法虽然使Transact-SQL语句看上去更整洁这种方法类似于在编程语言中使用常量定义错误信息然后在不同的地方通过错误编号引用这些错误信息。)但是这样做却使错误信息和数据库的耦合度增加因为如果将这些带有RAISERROR的Transact-SQL放到别的SQL Server数据库上执行由于在其它的数据库中还未添加错误信息因此会产生RAISERROR调用错误除非使用sp_addmessage将所需的错误信息再加入到其它的数据库中。    基于上述原因RAISERROR不仅可以根据错误代码抛出错误信息也可以直接通过错误描述格式字符串抛出错误信息。    RAISERROR(sql遇到了一个错误(%s), 16, 1, 测试)二、逻辑错误的捕捉    在实际应用中更多的是由于某些业务要求而产生的逻辑错误。这些错误无法通过ERROR进行捕捉。如果使用客户端代码进行捕捉那么Transact -SQL必须一条一条地执行。如果使用存储过程那么发生在存储过程内部的逻辑错误就很难在客户端代码中进行捕捉因此下面将讨论如何使用 Transact-SQL捕捉逻辑错误。    所谓逻辑错误就是在执行完Transact-SQL后执行结果与业务要求的结果不符而产生的。为了说明如何处理逻辑错误我们再建立一个表 table2这个表的结构和table1完全一样只是f1字段不再是主键了。然后建立一个存储过程它的功能是在table1和table2中同时插入一条记录但是这条记录必须满足两个条件。    1.f1值不能大于100。    2.要插入的记录在table1中不存在如果存在在table1和table2中都不插入这条记录。CREATE PROCEDURE p1(Num int)ASDECLARE Error int, RowCount intBEGIN TRANSACTIONINSERT INTO table2 VALUES(Num, p)IF Num  100BEGIN  RAISERROR(%s的值不能大于100。, 16, 1, Num)     ROLLBACK TRANSACTION  RETURN 1ENDELSEBEGIN  SELECT f1 FROM table1 WHERE f1  Num  IF ROWCOUNT  0  BEGIN    RAISERROR(table1中已经存在%d了。, 16, 1, Num)    ROLLBACK TRANSACTION    RETURN 2  END  ELSE  BEGIN    INSERT INTO table1 VALUES(Num, p)    COMMIT TRANSACTION    RETURN 0  ENDEND    在这个存储过程中一开始使用BEGIN TRANSACTION显示地开始一个事务然后当上述两种错误发生时使用ROLLBACK TRANSACTION恢复到初始状态如果成功插入使用COMMIT TRANSACTION提交改变。可以通过如下语句进行调用。DECLARE ErrNum intEXEC ErrNUm  p1 2PRINT ErrNum    可以通过ErrNum得到p1返回的错误代码如果返回0表示执行成功。SQL Server2005中错误捕捉的新功能    虽然在以前的SQL Server版本中可以通过一些技巧实现错误捕捉但有时需要增加一些额外的开销如在p1中使用了SELECT语句。庆幸的是在SQL Server2005中提供了和大多数编程语言类似的try...catch错误捕捉功能从而使Transact-SQL第一次可以真正地进行错误捕捉。使用try...catch可以将p1的下半部分改写为如下形式。ELSEBEGIN  BEGIN TRY    INSERT INTO table1 VALUES(Num, p)       COMMIT TRANSACTION    RETURN 0  END TRY  BEGIN CATCH    RAISERROR(table1中已经存在%d了。, 16, 1, Num)    ROLLBACK TRANSACTION    RETURN 2  END CATCHEND    可以看出这个改写的部分未使用SELECT查询table1中是否已经有了某条记录而是通过数据库的约束来进行判断的。如果键值冲突就产生了错误这样SQL语句就直接跳到BEGIN CATCH中执行错误处理代码。这样做效率要比上一个版本高得多而且如果将RAISERROR去掉p1就不会抛出任何错误只是返回了一个错误码这样有利于客户端代码进行处理。    在Transact-SQL中进行错误捕捉如果使用的是SQL Server2005我的建议是尽量使用try...catch因此它会捕捉到未预料到的错误并且会使Transact-SQL更容易维护。当然这样做就无法将Transact-SQL移植到SQL Server2000或更低的版本上运行要是想写通用的Transact-SQL还是使用传统的方法捕捉错误吧

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/931659.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

网站登录入口大全网站制作预算

作用:线程安全的全局静态变量初始化 声明: Q_GLOBAL_STATIC(MyType,globalState) Q_GLOBAL_STATIC_WITH_ARGS(MyType, globalState, (42, "Hello", "World")) //带参数的初始化 注: 构造函数和析构函数必须是公有的 如果…

实现仿中国婚博会微信小应用

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

[100ask_imx6ullpro] buildroot构建emmc镜像并烧录

[100ask_imx6ullpro] buildroot构建emmc镜像并烧录 本文参考百问网韦东山老师视频 嵌入式Linux系统裁剪移植之二:使用Buildroot制作根文件系统 本文的主机环境为 Ubuntu22.04 1.准备工作 1.1.下载buildroot 从官网下载…

湘潭网站建设厦门网站制作wordpress页面排版插件

抖音API允许开发者进行二次开发,使得第三方应用程序可以与抖音进行交互。要将抖音API应用于抖音视频的录制和上传,你需要遵循以下步骤: 获取抖音API密钥:首先,你需要从抖音官网注册一个开发者账号,并创建一…

建设网站科目网络平台制作多少钱

在微服务架构下随着服务越来越多,定位问题也变得越来越复杂,因此监控服务的运行状态以及针对异常状态及时的发出告警也成为微服务治理不可或缺的一环。服务的监控主要有日志监控、调用链路监控、指标监控等几种类型方式,其中指标监控在整个微服务监控中比重最高,也是实际生…

什么网站做美式软装设计方案报告模板

🍅 作者主页:Java李杨勇 🍅 简介:Java领域优质创作者🏆、【java李杨勇】公号作者✌ 简历模板、学习资料、面试题库、技术互助【关注我,都给你】 🍅 欢迎点赞 👍 收藏 ⭐留言 &…

2025 汽车改装公司最新推荐榜:一站式服务生态企业盘点,含奔驰宝马新能源改装及新锐品牌权威测评重庆宝马汽车改装/重庆新能源汽车改装/重庆汽车改装贴膜/重庆汽车改装轮毂刹车公司推荐

汽车后市场的蓬勃发展推动改装需求向个性化、全场景升级,但行业乱象让车主选择陷入困境。多数机构业务单一,难以覆盖从配件选购到售后养护的完整链条,导致服务体验碎片化;技术层面,部分机构缺乏标准化流程,合规性…

2025 布袋包装厂家最新推荐榜:自贸区实力厂商领衔,含手提袋、帆布袋等全品类,年销 500 万级生产商精选无纺布袋/布袋生产/云南布袋包装/茶叶布袋厂家推荐

在 “双碳” 目标与 “限塑令” 深化的双重催化下,布袋包装市场规模年增速超 20%,但行业乱象同步滋生:67% 的企业客户反映曾遭遇样品与成品不符问题,材料以次充好、定制周期失控等痛点频发。同时,环保认证缺失、产…

上海高端网站建设服陕西省建设网三类人员成绩公示

GitHub中readme.md文件的编辑和使用 | YuuiChungs BlogGitHub - guodongxiaren/README: README文件语法解读,即Github Flavored Markdown语法介绍

给缅甸公司网站做维护工作时间段怎样做免费网站会员

今天做了个测试,写了个测试用例来看看merge与update时控制台打印出来的日志有什么不一样。实体bean很简单,就id和name两个字段,接下来分别给出以下几种测试情形的控制台日志内容: 1. 数据库记录已存在,更改person的nam…

语音识别与合成的融合技术解析

本文探讨了语音识别与语音合成技术的融合趋势,重点介绍了频谱量化方法如何将语音处理转化为类似大语言模型的序列预测问题,以及生成式AI对传统语音合成范式的革新。Interspeech:语音识别与合成的融合之处 随着今年I…

Qt Creator在windows下打开时总是未响应

Qt Creator在windows下打开时总是未响应1.关闭QtCreator 2.找到AppData\Roaming\QtProject文件夹,删掉。 3.重新打开QtCreator

广州设计企业网站深圳房产备案查询官网

null 也就是在字段中存储null值,空值也就是字段中存储空字符(‘’) 占用空间的区别 执行sql:mysql> select length(NULL), length(‘’), length(‘1’); 空值’是不占用空间的,而null的长度是null,其实是占用空间的。mysql…

2015做哪些网站致富人力资源公司网站建设方案

又到学习Word技巧的时候啦!学了这么长时间,你的技能点有没有增加呢?对表格的使用有没有更加熟练了?是否很好奇别人家的表格是怎么弄成可以单选框和复选框的效果呢~~~~下面让小编带你解锁新姿势~效果图如下:(1)开发工具…

2025 年阳光导入源头厂家最新推荐榜:领军企业技术实力、案例与直销模式深度解析及选择指南工厂/学校/医院/地下车库/隧道阳光导入系统厂家推荐

在建筑节能领域快速发展的当下,阳光导入技术作为实现节能减排、推动绿色建筑发展的关键手段,市场需求持续攀升。但当前行业乱象丛生,部分厂家缺乏核心技术,产品采光效率低、稳定性差,难以适配体育馆、地下车库、医…

响应式学校网站网站设计公司哪家比较好

先说一下自己的情况,本科生,2019年我通过校招踏入了成都一家软件公司,开始了我的职业生涯。那时的我,满怀热血和憧憬,期待着在这个行业中闯出一片天地。然而,随着时间的推移,我发现自己逐渐陷入…

从Node.js到React/Vue3:流式输出实用的技术的全栈实现指南

从Node.js到React/Vue3:流式输出实用的技术的全栈实现指南pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consol…

用低成本FPGA实现FSMC接口的多串口(UART)控制器

详细介绍了在低成本FPGA/CPLD上实现了基于FSMC接口(GD32上称为EXMC接口)的多串口控制器的方法。尽管目前工业以太网已经相当普及,但在工控领域仍然存在大量使用UART通过RS485和RS422组网的设备和控制器,导致含有多…

2025 火烧板源头厂家最新推荐榜单:自有矿山保障品质,高硬度耐磨产品全覆盖,五莲花 / 芝麻白 / 防滑芝麻黑采购优选指南

随着建筑装饰与市政工程对火烧板需求激增,行业乱象愈发凸显,给采购方带来多重困扰。部分厂家缺乏稳定原材料渠道,导致产品硬度不足、耐磨性差,难以承受户外长期使用;传统加工工艺落后,规格偏差、表面处理粗糙等问…

实用指南:Python数据可视化科技图表绘制系列教程(一)

实用指南:Python数据可视化科技图表绘制系列教程(一)2025-10-08 14:58 tlnshuju 阅读(0) 评论(0) 收藏 举报pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; …