如何实现PostgreSQL函数自定义例外处理
发表于:2024-11-17 作者:千家信息网编辑
千家信息网最后更新 2024年11月17日,这篇文章主要为大家展示了"如何实现PostgreSQL函数自定义例外处理",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"如何实现PostgreSQL函数自定
千家信息网最后更新 2024年11月17日如何实现PostgreSQL函数自定义例外处理
这篇文章主要为大家展示了"如何实现PostgreSQL函数自定义例外处理",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"如何实现PostgreSQL函数自定义例外处理"这篇文章吧。
代码搬运也需要发挥想象力,让不可能变为可能,这里讲一个例子。
1、 有人问PostgreSQL有没有自定义例外,Oracle是有的:
--定义myex Exception;--抛出RAISE myex;--捕获WHEN myex THEN
简单易用
2、再来看PostgreSQL的PL/pgSQL
RAISE [ level ] condition_name [ USING option = expression [, ... ] ];RAISE [ level ] SQLSTATE 'sqlstate' [ USING option = expression [, ... ] ];
这两种语法似乎有一定的灵活性,实际上它们只能使用预定义的例外,文档中有说明,如果不能识别会报错。
ERROR: unrecognized exception condition "xxxxxxx"CONTEXT: compilation of PL/pgSQL function "func_a" near line 3ERROR: invalid SQLSTATE code at or near "'12345'"LINE 5: RAISE SQLSTATE '12345' USING MESSAGE = 'zzz';
3、代码实现
这段是强行加戏,防止篇幅过小的一个例外处理,完全可以跳过而不会有任何影响。
for (i = 0; exception_label_map[i].label != NULL; i++) { if (strcmp(condname, exception_label_map[i].label) == 0) return exception_label_map[i].sqlerrstate; }
这里可以看出,能使用的名字或编码在编译时已经确定,不能自己定义。
4、但是,我们仍有办法可以做到
尽量选择一个上下文无关的错误,也就是这段代码不可能会抛出的例外,避免程序出错被错误拦截。
比如:0A000 feature_not_supported
我们可以抛出一个例外,用错误信息标记它的特殊性:
RAISE SQLSTATE '0A000' USING MESSAGE = 'flying0001:failed to ...';
在捕获它时可以按条件处理:
WHEN SQLSTATE '0A000' THEN DECLARE m text; BEGIN GET STACKED DIAGNOSTICS m = MESSAGE_TEXT; IF ( strpos(m, 'flying0001:')=1) THEN RAISE WARNING 'got flying0001'; ELSIF ... END IF; END;
虽然啰嗦,但确实是实现了同样的功能。
5、完整演示
也是加戏,凑篇幅用。
CREATE OR REPLACE FUNCTION func_a()RETURNS void AS$$BEGINRAISE SQLSTATE '0A000' USING MESSAGE = 'flying0001:Do one thing at a time, and do well.';EXCEPTIONWHEN feature_not_supported THEN DECLARE m text; BEGIN GET STACKED DIAGNOSTICS m = MESSAGE_TEXT; IF (strpos(m, 'flying0001:')=1) THEN RAISE WARNING 'got flying0001'; END IF; END;END;$$LANGUAGE plpgsql;
以上是"如何实现PostgreSQL函数自定义例外处理"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
处理
函数
代码
内容
篇文章
错误
篇幅
学习
帮助
特殊
上下
上下文
不能自己
也就是
例子
信息
办法
功能
名字
实际
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
蛋白gg服务器
软件开发项目试运行记录模板
万方数据库官网下载
计算机类 网络安全类 专业
tbc部落哪个服务器g团多
wow不同服务器交易
数据库 过程
学生与教师的关系数据库
天龙八部服务器架设
上海网络金融网络技术服务热线
数据库设计的第一阶段是
百度外卖是互联网科技公司吗
温州办公软件开发
数字文化创意软件开发项目开工
城镇化 数据库建设
灵武市软件开发公司怎么收费
科技互联网发展现状
delphi软件开发有前途吗
软件开发 标准有哪些
海珠区无源网络技术开发商家
如何同步备用数据库
网络安全加密算法论文
本地数据库在同局域网链接
数据库学完后的感想
哪些软件开发工作只需要基础
服务器没有声音了
联想服务器是国产还是非国产
湖南湘雅夕乐园招软件开发
关于网络安全和心得体会
网络安全手抄报内容素材