PL/SQL Select into 异常处理
在使用select into 为变量赋值时,如果变量是集合类型,不会产生异常,而如果是基本类型或记录类型,则会报异常。
异常产生了怎么办?当然是捕获并处理啦。
对于普通的代码块来说,在代码块的结尾处理就可以了。
但是在循环里面呢?根据异常的传播,产生异常程序会中止。但如果想要在发生异常后,达到continue的效果,可不能在结尾的exception那里添加when others then continue;的语句,否则报错。
要达到在循环中,找不到数据就continue,可以在赋值时,no_data_found的情况下作异常处理。即是让赋值语句包含在begin exception end的结构中。
另外,记录类型不能被整体判断为空,可以修改某列的值来判断,或者使用一个标志变量判断。
下面是一个小例子,我们一起感受一下。
1 declare 2 v_test2 studentRecord;--遍历游标 3 v_test3 studentRecord;--每次取出的记录 4 cursor c_test is 5 select * 6 from student_head h 7 where h.student_key in (3285, 3286, 3287, 3288); 8 flag boolean; 9 begin 10 open c_test; 11 loop 12 fetch c_test into v_test2; 13 exit when c_test%notfound; 14 flag := true; 15 begin 16 select * 17 into v_test3 18 from student_head 19 where student_key = v_test2.student_key 20 and student_status <> 'CNX'; 21 exception 22 when no_data_found then--select into 没有数据时,如果是集合类型不会产生异常,记录类型报异常 23 flag := false; 24 end; 25 /*if v_test3 is null*/--记录类型不能整体判断为空 26 if flag then--判断是否有找到数据 27 dbms_output.put_line(v_test3.student_key || ' ' || v_test3.student_no); 28 end if; 29 end loop; 30 close c_test; 31 /*exception 32 when no_data_found then continue ;*/ -- 不能在异常中使用continue 33 -- 如果在此处理异常,会导致循环中止,要达到continue的效果,可在每次赋值进行异常处理 34 end;
分类:
Oracle & PL/SQL
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 使用C#创建一个MCP客户端
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 按钮权限的设计及实现