Oracle常见错误:ORA-01403 ORA-06512: 在 "MALL.PUB_YANG_LOGON_ORGAN", line 88 ORA-06512: 在 line 1     at com.yangcq.flow.processflow.ProcessflowFunction.execute(ProcessflowFunction.java:102)     at com.opensymphony.workflow.AbstractWorkflow.executeFunction(AbstractWorkflow.java:869)     at com.opensymphony.workflow.AbstractWorkflow.transitionWorkflow(AbstractWorkflow.java:1042)     at com.opensymphony.workflow.AbstractWorkflow.doAction(AbstractWorkflow.java:567)     at com.yangcq.flow.processflow.BaseProcessflow.executeProcessflow(BaseProcessflow.java:65)     at com.yangcq.flow.processflow.BaseProcessflow.executeProcessflow(BaseProcessflow.java:39)     at com.yangcq.web.spring.DefaultFlowExecuteHandler.executeProcessflow(DefaultFlowExecuteHandler.java:58)     at com.yangcq.service.ProcessflowExecuteService.execute(ProcessflowExecuteService.java:164)     at com.yangcq.flow.processflow.function.ProcessflowExecFunction.exec(ProcessflowExecFunction.java:33)     ... 48 more Caused by: com.yangcq.Exception: root cause: SqlMapClient operation; SQL [];    --- The error occurred in config/sqlmap/public.xml.   --- The error occurred while applying a parameter map.   --- Check the public.pwdErrorOperate.   --- Check the statement (update procedure failed).   --- Cause: java.sql.SQLException: ORA-01403: 未找到任何数据 88行的SQL是这样的(为了便于阅读,我把这行代码进行了格式化,多行显示):     SELECT     LCL_LASTFAIL,LCL_FAILTODAY INTO V_LASTDATE, V_FAILCOUNT FROM     CB_LOGON_CTRL WHERE     LCL_BRANCHID = IN_BRANCHID AND     LCL_USERID = IN_CSTNO||IN_USERID; 根本原因:SELECT语句查询出来的结果为空,此时把查询出来的空值赋给2个变量,就出现了上面这个错误。ORA-01403: 未找到任何数据,报这个错误 通常都是SELECT INTO 语句查询结果为空的原因。这个报错是我们在使用PL/SQL进行调试时,经常遇到的一个问题。 解决方案:查看一下是不是数据的问题,导致查询结果为空。 如果我们使用Oracle的异常处理机制来捕获这个异常的话,控制台就不会打印错误信息了。 Oracle异常处理机制 为了开发和维护的方便,Oracle定义了常见的异常,主要有以下几个: 1,DUP_VAL_ON_INDEX        异常码 ORA-00001        试图向唯一索引列插入重复值 2,INVALID_CURSOR        异常码 ORA-01001        试图进行非法游标操作 3,INVALID_NUMBER        异常码 ORA-01722        试图将字符串转化成数字 4,NO_DATA_FOUND        异常码 ORA-01403        SELECT INTO 语句中没有任何返回结果 5,TOO_MANY_ROWS        异常码 ORA-01422        SELECT INTO 语句中返回结果 6,ZERO_DIVIDE        异常码 ORA-01476        试图用0作为除数 7,CURSOR_ALREADY_OPEN        异常码 ORA-06511        试图打开一个已经打开的游标 PL/SQL中用EXCEPTION关键字来作为异常的开始标志。一旦一个存储过程发生异常,就会执行异常语句之后的SQL。 扩展阅读:Oracle中的ROWNUM关键字 在查询的结果集中,ROWNUM关键字为结果集中的每一行标识一个行号,第一行返回1,第二行返回2...,以此类推。通过ROWNUM关键字,我们可以控制查询的记录数。如下: SELECT * FROM ENT_ROLE WHERE ROWNUM < 10;  --查询ENT_ROLE中的前9条记录 ROWNUM与ROWID的区别:ROWID是插入记录时生成的,标识的是行的物理地址;ROWNUM是查询数据时生成的,标识的是查询结果中行的顺序。 关于ROWNUM还有一点需要说明的就是,下面的写法,不返回任何查询结果: SELECT * FROM ENT_ROLE WHERE ROWNUM > 10; SELECT * FROM ENT_ROLE WHERE ROWNUM >= 10; 那么Oracle如何实现分页呢? --Oracle分页查询 SELECT   * FROM   (     SELECT         ROWNUM R,YANGCQ_ID,YANGCQ_BRANCHID     FROM         YANGCQ_USER     WHERE         ROWNUM <= 10     ) WHERE     R > 5; 流程解析:第一步内部查询得到ROWNUM ,并且起个别名R;然后外部查询使用的R列,其实是内层查询的一个列,而不是行的标号了。 同样的,也可以采用类似的方法: SELECT   * FROM   (     SELECT         ROWNUM R,YANGCQ_ID,YANGCQ_BRANCHID     FROM         YANGCQ_USER     ) WHERE     R > 5 AND     R <= 10;

oracle ora-01476: 除数为 0,Oracle常见错误:ORA-01403 的根本原因和解决方案相关推荐

  1. oracle触发器ora01403,Oracle常见错误:ORA-01403 的根本原因和解决方案

    Oracle常见错误:ORA-01403 ORA-06512: 在 "MALL.PUB_YANG_LOGON_ORGAN", line 88 ORA-06512: 在 line 1 ...

  2. tomcat一段时间不操作oracle就关闭连接_操作数据库常见错误,开发人员必掌握的技能...

    人生路,靠不得任何人,只能靠自己.那些该吃的苦,一点都不能少,那是我们通向未来必须要走的路,从泥泞不堪,布满荆棘的小道上迈步,才能踏上铺满鲜花的大道. 前言 作为一个开发人员虽然有时候对于数据库这方面 ...

  3. linun开启oracle监听,Linux下配置Oracle监听器

    1. 修改监听器配置文件 Linux下Oracle监听器配置文件在:$ ORACLE_HOME/network/admin/listerer.ora, 如: /bank/oracle/oracle10 ...

  4. oracle 三步运算符,ORA-01476: 除数为 0

    假设是a/b decode(b,0,null,a/b) 这样如果b为0,输出null,不为0输出a/b decode():将查询结果翻译成其他值,类似三目运算符 比较1个参数时      decode ...

  5. Oracle 常见错误总结(如:ORA-XXXXX)及问题解决方法

    转: Oracle 常见错误总结(如:ORA-XXXXX)及问题解决方法 ORA-00001: 违反唯一约束条件 ORA-00017: 请求会话以设置跟踪事件 ORA-00018: 超出最大会话数 O ...

  6. oracle ora 00283,【案例】Oracle报错ORA-16433非归档丢失redo无法启动的恢复过程

    天萃荷净 Oracle研究中心案例分析:运维DBA反映Oracle数据库处理非归档模式,redo文件损坏常规修复无法正常open数据库. 本站文章除注明转载外,均为本站原创: 转载自love wife ...

  7. oracle错误01653,oracle 10g 错误 ORA 01653 的解决过程

    oracle 10g 错误 ORA 01653 的解决过程 早上用户反应在操作用友NC时报错 ORA-01653 ,详细信息:ORA-01653: 表 NCV35.GL_DETAIL 无法通过 102 ...

  8. Oracle 常见错误总结及问题解决方法

    ORA-00001: 违反唯一约束条件  ORA-00017: 请求会话以设置跟踪事件 ORA-00018: 超出最大会话数 ORA-00019: 超出最大会话许可数 ORA-00020: 超出最大进 ...

  9. itpub上的ORACLE之常用FAQ V1.0(转)

    itpub上的ORACLE之常用FAQ V1.0发布于2005-06-01 被读23598次 [字体:大 中 小] 作者:itpub 第一部分.SQL&PL/SQL [Q]怎么样查询特殊字符, ...

最新文章

  1. SQLserver 常用函数适用方法(转载)
  2. Android Studio 选项菜单和动画结合_谷歌准备为Android增加像iOS一样的功能
  3. GT Transceiver的动态重配置端口
  4. 正则表达式 学习笔记5.3
  5. Java NIO理解与使用
  6. SPC.NET,为5年的开发做个结尾
  7. 易优cms问一下大家 二级目录 真的完全不能装吗
  8. 同时学cpa和Java_2019年,CPA可以和哪些证书同时备考?
  9. LeetCode 1004.最长连续1的个数
  10. SpringBoot切换Tomcat容器,SpringBoot使用Jetty容器
  11. 如何使用 ADO.NET 和 Visual C# .NET 调用带参数的存储过程
  12. [react] 怎样在react中使用innerHTML?
  13. 悬浮窗_华为手机悬浮窗设置在哪里
  14. Postgres访问其他PostgresQL数据库的功能DBLINK
  15. [转载] 在python中pop的用法_python中pop()函数如何使用
  16. win10快捷键启动屏幕保护程序
  17. QComboBox下拉框
  18. UNITY设计一款简单的3d射击小游戏(虚拟现实大作业)
  19. 仙人掌之歌——直播业务立项(2)
  20. Codeforces Daily (Round 370-410)

热门文章

  1. SAP License:转一篇初学者必看的文章
  2. 小心SAP环境中的8大安全错误!快来对照、改正!
  3. 如何将自己的代码发布到Maven中央仓库?
  4. laradock 进入 工作区
  5. redis linux中的安装
  6. PHP自动加载下——PSR4
  7. FairScheduler的任务调度机制——assignTasks
  8. 【LuoguP5289】[十二省联考2019] 皮配
  9. Openstack Python 源代码的路径
  10. iOS--控制器加载自定义view的xib