[20180502]PLDEVELOP与存储过程调试.txt-阿里云开发者社区

开发者社区> lfreeali> 正文

[20180502]PLDEVELOP与存储过程调试.txt

简介: [20180502]PLDEVELOP与存储过程调试.txt --//今天遇到一个调式问题.做一个记录: 1.环境: SCOTT@book> @ ver1 PORT_STRING                    VERSION        B...
+关注继续查看

[20180502]PLDEVELOP与存储过程调试.txt

--//今天遇到一个调式问题.做一个记录:

1.环境:
SCOTT@book> @ ver1
PORT_STRING                    VERSION        BANNER
------------------------------ -------------- --------------------------------------------------------------------------------
x86_64/Linux 2.4.xx            11.2.0.4.0     Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production

--//建立过程如下:

CREATE OR REPLACE PROCEDURE oratest (a VARCHAR2, b VARCHAR2)
AS
   c   VARCHAR2(32767);
BEGIN
   c := a || b;
   DBMS_OUTPUT.put_line (a || b);
END oratest;
/

--//另外写法:
CREATE OR REPLACE PROCEDURE oratest1 (a VARCHAR2, b VARCHAR2)
AS
   c   VARCHAR2(32767);
BEGIN
   c := a || b;
   DBMS_OUTPUT.put_line (c);
END oratest;
/


SCOTT@book> exec oratest(lpad('a',255,'a'),'b');
aaaaaaaaaaaaaa....
aaaab

PL/SQL procedure successfully completed.

--//在sqlplus以及toad下执行如下:
DECLARE
  A VARCHAR2(32767);
  B VARCHAR2(32767);

BEGIN
  A := lpad('a',255,'a');
  B := 'b';

  SCOTT.ORATEST ( A, B );
  COMMIT;
END;
/

2.但是如果使用pl develop的test windows:
begin
  -- Call the procedure
  oratest(a => :a,
          b => :b);
end;


--//如果输入参数字符串总和长度大于255,就会出现错误:
ORA-06502:PL/SQL:number or value error: host bind array too small.
--//即使type选择PL/SQL string也是一样.
--//我使用PL的版本 6.0.0.840.

https://blog.csdn.net/zzy7075/article/details/8559358

--//经过分析,在客户端为9i的机器上运行这个sql,其最大长度限制是255,在10g上运行,最大长度限制是32767.
--//找了一台9i的windows服务器测试看看.

SQL> select * from v$version;
BANNER
----------------------------------------------------------------
Oracle9i Enterprise Edition Release 9.2.0.8.0 - Production
PL/SQL Release 9.2.0.8.0 - Production
CORE    9.2.0.8.0       Production
TNS for 32-bit Windows: Version 9.2.0.8.0 - Production
NLSRTL Version 9.2.0.8.0 - Production

SQL> CREATE OR REPLACE PROCEDURE oratest (a VARCHAR2, b VARCHAR2)
  2  AS
  3     c   VARCHAR2(32767);
  4  BEGIN
  5     c := a || b;
  6     DBMS_OUTPUT.put_line (a || b);
  7  END oratest;
  8  /
过程已创建。

SQL> set serverout on
SQL> exec oratest(lpad('a',255,'a'),'b');
BEGIN oratest(lpad('a',255,'a'),'b'); END;

*
ERROR 位于第 1 行:
ORA-20000: ORU-10028: line length overflow, limit of 255 chars per line
ORA-06512: 在"SYS.DBMS_OUTPUT", line 35
ORA-06512: 在"SYS.DBMS_OUTPUT", line 133
ORA-06512: 在"SYSTEM.ORATEST", line 6
ORA-06512: 在line 1

SQL> exec oratest(lpad('a',254,'a'),'b');
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
aaaaaaaaaaaaaab
PL/SQL 过程已成功完成。

SQL> set serveroutput on size 10000
SQL> exec oratest(lpad('a',255,'a'),'b');
BEGIN oratest(lpad('a',255,'a'),'b'); END;

*
ERROR 位于第 1 行:
ORA-20000: ORU-10028: line length overflow, limit of 255 chars per line
ORA-06512: 在"SYS.DBMS_OUTPUT", line 35
ORA-06512: 在"SYS.DBMS_OUTPUT", line 133
ORA-06512: 在"SYSTEM.ORATEST", line 6
ORA-06512: 在line 1

--//我的pl/develop的client是10.2.0,难道里面的某些dll版本还是9i的东西.放弃,好在我不用pl/delelop.不过开发遇到这个问题,以后工作注意.

--//另外好像在拼接时开始报错...

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
阿里云服务器怎么设置密码?怎么停机?怎么重启服务器?
如果在创建实例时没有设置密码,或者密码丢失,您可以在控制台上重新设置实例的登录密码。本文仅描述如何在 ECS 管理控制台上修改实例登录密码。
9485 0
使用NAT网关轻松为单台云服务器设置多个公网IP
在应用中,有时会遇到用户询问如何使单台云服务器具备多个公网IP的问题。 具体如何操作呢,有了NAT网关这个也不是难题。
26735 0
阿里云服务器ECS远程登录用户名密码查询方法
阿里云服务器ECS远程连接登录输入用户名和密码,阿里云没有默认密码,如果购买时没设置需要先重置实例密码,Windows用户名是administrator,Linux账号是root,阿小云来详细说下阿里云服务器远程登录连接用户名和密码查询方法
11191 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,阿里云优惠总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系.
13168 0
windows server 2008阿里云ECS服务器安全设置
最近我们Sinesafe安全公司在为客户使用阿里云ecs服务器做安全的过程中,发现服务器基础安全性都没有做。为了为站长们提供更加有效的安全基础解决方案,我们Sinesafe将对阿里云服务器win2008 系统进行基础安全部署实战过程! 比较重要的几部分 1.
9049 0
阿里云ECS云服务器初始化设置教程方法
阿里云ECS云服务器初始化是指将云服务器系统恢复到最初状态的过程,阿里云的服务器初始化是通过更换系统盘来实现的,是免费的,阿里云百科网分享服务器初始化教程: 服务器初始化教程方法 本文的服务器初始化是指将ECS云服务器系统恢复到最初状态,服务器中的数据也会被清空,所以初始化之前一定要先备份好。
6886 0
阿里云服务器ECS登录用户名是什么?系统不同默认账号也不同
阿里云服务器Windows系统默认用户名administrator,Linux镜像服务器用户名root
4008 0
+关注
lfreeali
熟悉oracle数据库性能优化,rman备份,数据库恢复技术.
2122
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载