1.今天写的存储过程在执行过程中,报如下错误. exec PRO_T_008pro_update_add_delete(17,1,1,1,1,45.0,54.0,45.0,45.0,45.0,54.0,45.0,54.0,'生产厂家','CYB10-2',54.0,45.0,25.0,1.0,45.0,25.0,1.0,45.0,25.0,1.0,45.0,1,4545.0,0,0,0,'no'); begin PRO_T_008pro_update_add_delete(17,1,1,1,1,…
目录(?)[+] 1. 问题起因 最近在进行Oracle的一些操作时,总会遇到这个错误:  ORA-06502: PL/SQL: 数字或值错误 :  字符串缓冲区太小,错误如下: ORA-00604: 递归 SQL 级别 1 出现错误 ORA-06502: PL/SQL: 数字或值错误 :  字符串缓冲区太小 ORA-06512: 在 line 7 2.官方解释 查看官方文档上的解释: ORA-06502: PL/SQL: numeric or value errorstring Cause:…
场景: .Net程序调用Oracle方法 command.ExecuteNonQuery()执行存储过程;弹出如标题异常信息. 存储过程有4个输入参数,一个输出参数.一旦执行到给输出参数赋值的时候就报错.但在Plsql环境下调度,是正常的. 分析: 查阅各帖子,都说是变量长度不够,但设置也无果. 后来,怀疑是不是设置参数顺序有问题,调整,搞定. 解决: 存储过程中定义的参数,第一个为out,虽然在设置参数时,用了参数名,但好像没起什么作用.所以,把输出参数第一个设置,与定义顺序一致,就OK了.…
该函数作用是把列值合并(用英文逗号分割),但是数量有限制,返回的字符数上线是4000(oracle11g),超过会报错,听说oracle版本到 11.2.0.2.0 或以上返回的是clob类型,长度就很长了,但是没有试过select wm_concat(colName) from table…
这个BUG出现会报错如下: selectto_char(max(RENEWAL_DATE)) intoM_YEAR_MONTH fromt_renewal_schedule; ORA-06502: PL/SQL:数字或值错误: 字符串缓冲区太小 这个时候有3个方法可以解决 1.setting initialisation parameter BLANK_TRIMMING=TRUE 2.declare PL/SQL CHAR and VARCHAR2 variable used in the IN…
今天在调试某个问题的时候,由于使用了很多循环,我需要都打印出来,试图使用clob整体处理之后再打印. 最后抛出此异常:数字或值错误. 网友解释如下: $ oerr ora 650206502, 00000, "PL/SQL: numeric or value error%s"// *Cause: An arithmetic, numeric, string, conversion, or constraint error// occurred. For example, this er…
SQL Server 2008 R2评估期已过的解决办法   发现问题 北美产品测试服每日随机任务没有刷新 每日随机任务是使用数据库作业定期执行操作,重置玩家随机任务项 排查问题  www.2cto.com   检查相应作业的状态.配置及启动时间均没问题 查看作业运行日志,发现近期作业运行失败 日志记录为:Description: Integration Services evaluation period has expired.  End Error  Could not execute p…
编译无效对象是DBA与数据库开发人员常见的工作之一.对于编译过程中的错误该如何去捕获,下面给出两种捕获错误的方法. 一.当前数据库版本信息及无效对象 1.查看当前数据库版本 [sql] view plain copy print? 1.SQL> select * from v$version; 2. 3.BANNER 4.---------------------------------------------------------------- 5.Oracle Database 10g E…
PL/SQL登录很短时间session就自动断开 1.首先查看你这个用户的profile文件 select profile from dba_users where username='USERNAME'; 2.查看一下profile文件中的idle_time设置 select * from dba_profiles where profile='PROFILENAME'; 3.如果第二步查找的idle_time值很小,修改为UNLIMITED不限制 alter profile prfilena…
环境 Oracle 11.2.0 + SQL Plus 问题 根据以下要求编写函数:将scott.emp表中工资低于平均工资的职工工资加上200,并返回修改了工资的总人数.PL/SQL中有更新的操作,执行此函数报如下错误:ORA-16551: 无法在查询中执行 DML 操作. 解决 在声明函数时加上: PRAGMA AUTONOMOUS_TRANSACTION; 并在执行完DML后COMMIT. 操作日志 --登录到Oracle C:\Users\Wentasy>sqlplus wgb SQL*…