Spring StoredProcedure调用Oracle函数各种异常解决方法

Spring StoredProcedure调用Oracle函数各种异常解决方法其实也不是各种异常解决方法,只是出现了太多的异常我实在不知道有哪些,下面列举一下吧:1.PLS-00306:wrongnumberortypesofargumentsincallto’QUERYUSER’ORA-06550:line1,column7:PL/SQL:Statementignored原因:这个问题是少参数,或者类型不对,我的原因是函数的…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

其实也不是各种异常解决方法,只是出现了太多的异常我实在不知道有哪些,下面列举一下吧:

1.PLS-00306: wrong number or types of arguments in call to ‘QUERYUSER’
ORA-06550: line 1, column 7:
PL/SQL: Statement ignored

原因:这个问题是少参数,或者类型不对,我的原因是函数的返回值没有接收,也就是没有设置函数返回值的参数;

解决方法:加上个asp.addOutParameter(“n_Result”, Types.INTEGER);// 函数返回结果,就可以解决。

2.ORA-00604: error occurred at recursive SQL level 1
ORA-01003: no statement parsed

原因:这个问题是因为添加参数的顺序问题,我把接收返回值的参数放在了输出参数的前面,就出现了这样的异常,原因包你找死找不出来,

解决方法:将接收返回值参数的代码添加到所有参数的最前面就可以了

还有其他的问题其实也都是对于调用函数时的设置参数顺序的问题 各种不同顺序出现的一场可能不一样,而且这种异常你上网都找不出解决方案,现在总结下Spring StoredProcedure调用Oracle函数的参数设置顺序:

1.接收函数返回值的代码必须写在最前面

2.然后接下来就输入参数和输出参数,这个顺序必须和函数定义的参数顺序一致才行,不然又是各种不认识的异常

3.最好把输出参数写在最后面,当时第二点说了,顺序要和函数定义的参数顺序一致,所以建议函数定义的时候输出写在输入后面,我没尝试函数定义时输出写在输入前面,然后代码也同样顺序会不会出问题,有兴趣的自己尝试吧,我懒了。

当然当你遇到这些问题的时候这只是个参考,不能确保能解决你得问题,我只是把我遇到的问题记录下来,总之我是这样解决的,所以解决不了也不要来骂我啊惊讶

最后说一句Spring能不能智能点 这种坑爹的问题都能出 太伤人了 设置参数的时候不是给了参数名吗 干嘛还要这么纠结参数顺序啊 而且也没有哪里提到过抓狂

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/164510.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • java测试面试问题_struts2面试题

    java测试面试问题_struts2面试题Javashiro面试题1、简单介绍一下Shiro框架?ApacheShiro是Java的一个安全框架。使用Shiro可以非常容易的开发出足够好的应用。其不仅可以用在JavaSE环境,也可以用在JavaEE环境。Shiro可以帮助我们完成功能:认证、授权、加密、会话管理、与Web集成、缓存等。三个核心组件:Subject,SecurityManager和Realms。●Subject:即“当…

    2022年10月14日
    4
  • c2框架编写

    0x00前言由于昨天520,今天又是521,我被朋友圈和qq空间给刷屏了,都在秀对象。一气之下决定把我上次写的nc拿出来使用类进行重构,多实例化几个对象,这下子我也有对象了。0x01一些小插曲

    2021年12月11日
    47
  • nginx负载均衡的5种策略及原理

    nginx负载均衡的5种策略及原理nginx的upstream目前支持的5种方式的分配1、轮询(默认)每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。 upstreambackserver{ server192.168.0.14; server192.168.0.15; } 2、指定权重指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。 upst…

    2022年6月29日
    54
  • VMWare虚拟机的三种网络配置

    VMWare虚拟机的三种网络配置背景:当前物理机ip:192.168.18.8,路由器IP:192.168.18.1(相当于网关)我学习linux系统时,在主机上配置了二种网络类型,其中NAT模式不需要关闭防火墙即可与主机相互pin

    2022年7月1日
    27
  • mysql日志文件位置_linux怎么导出日志文件

    mysql日志文件位置_linux怎么导出日志文件登录mysql终端mysql-uroot-p输入密码:进入mysql>1.日志文件路径mysql>showvariableslike‘general_log_file’;±—————–±———————————–+|Variable_name|Value|±—————–±———————————–+|general_log_f

    2022年8月31日
    5
  • 使用docker启动mysql8.0挂载配置文件_docker的特点

    使用docker启动mysql8.0挂载配置文件_docker的特点使用docker启动MySQL8.0因为mysql8对登录密码的加密方式做了调整,所以每次安装完mysql都要去翻翻教程,特此记录下,方便以后查看docker启动脚本#!/bin/bashdockerrm-fmysql8dockerrun–namemysql8\-eMYSQL_ROOT_PASSWORD=123456\-v/usr/local/mysql/logs:/logs\-v/usr/local/mysql/data:/var/lib/mys

    2022年10月5日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号