如何实现PostgreSQL函数自定义例外处理
发表于:2025-12-02 作者:千家信息网编辑
千家信息网最后更新 2025年12月02日,这篇文章主要为大家展示了"如何实现PostgreSQL函数自定义例外处理",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"如何实现PostgreSQL函数自定
千家信息网最后更新 2025年12月02日如何实现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安全错误
数据库的锁怎样保障安全
车乐保互联网科技
为什么登录时服务器尚未开启
天津智慧养老软件开发专业制作
数据库字体放大
网络安全行业股票有哪些
深圳软件开发夏前锋
软件开发工资为什么这么高
金山区推广软件开发报价有哪些
集美大学思科网络技术基础
软件开发编程敲代码
大数据治理体系数据库设计
电信网络技术工程师月薪多少
svn服务器管理平台
机房网络安全维护方案
pg数据库ctid
系统软件开发人员在第几层
网络安全技术师证怎么考
沈阳高防服务器
电子琴软件开发技术
浩盛网络技术有限公司
网络安全blog
软件开发公司开展内部培训
幼儿园网络安全教育实施方案
java 复制数据库一条数据
光迅科技网络安全概念
河北通用软件开发调试
提升网络技术的好处
pg数据库ctid
云服务器怎么转移
大连网络安全教育视频