如何实现PostgreSQL函数自定义例外处理
发表于:2025-02-05 作者:千家信息网编辑
千家信息网最后更新 2025年02月05日,这篇文章主要为大家展示了"如何实现PostgreSQL函数自定义例外处理",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"如何实现PostgreSQL函数自定
千家信息网最后更新 2025年02月05日如何实现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安全错误
数据库的锁怎样保障安全
如皋租车软件开发
数据库设计考试答案
阿里云服务器登录续费
供销社建立网络安全机制
软件开发收入是it类收入吗
用友t6数据库安装视频
扬州多媒体视频系统服务器
寝室网络安全管理
软件开发阶段几个活动
如何提升网络安全管理
新兴传媒与网络安全
软件开发专业的毕业设计题目
四川中翼互联网科技
谜材网络安全词
武科大计算机网络技术试卷
软件开发商对公账户
太原叠威网络技术有限公司
怎么构建良好的网络安全环境
学习网络安全管理的目的
网吧服务器打开顺序
浅谈数据库技术的发展
香樟树软件开发公司
软件开发项目掩饰
excel倒出固定数据库
信息时代网络安全手抄报内容
怎么在阿里云买服务器吗
吉林电力卫星授时服务器虚拟主机
设置备用服务器
网络安全专业技术服务合同
有关股市的数据库