如何实现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安全错误
数据库的锁怎样保障安全
数据库数据类型
服务器可以用电源关机吗
微信群数据库
安全狗服务器退出用户名
服务器一般分几个区
新媒体网络技术的考核
服务器硬件冗余方案设计
服务器read都有哪些
数据库二级什么时候报名
哪个数据库可以免费下载论文
网络安全法第二十一条整改
互联网和信息网络技术
数据库定义表结构
服务器启动服务的指令
澳门果蔬配送软件开发
软件开发要掌握哪些编程语言
hivemc服务器支持什么版本
虎彩软件开发
服务器可以接入防火墙吗
绿书签2017网络安全
在银行做软件开发前景如何
棋牌游戏软件开发需要多少人
深圳服务器cpu回收
kms密钥管理服务器被入侵
校园网络安全宣传日手抄报
交通项目软件开发内容
九阴真经缘定三生是哪里服务器
服务器软硬件开发
华为服务器下载官网
网络安全攻防比赛实战教程