oracle 带参数存储过程无法执行解决方法
oracle 带参数存储过程无法执行
我创建了一个存储过程,不过执行的时候报错,请教大神原因何在?
还有个次要问题,我的程序中用的是System.Data.OracleClient 但是OracleType中没有VARCHAR2,如何自己添加一个?
报错如下
------解决思路----------------------
楼主 datefrom 和 dateto传入参数在动态sql里面没有用到而是用一个字符串去to_date。。。
------解决思路----------------------
------解决思路----------------------
楼主啊,两个字符串怎么连接啊? 不是用
------解决思路----------------------
去连接吗
比如 “ab”
------解决思路----------------------
"cd"的结果就是“abcd”
但是你这个sql本身就用单引号引起来了 然后单引号内部 两个单引号被当成一个单引号去解析 所以你的datatime就被当成字符串 而不是变量了 这根java代码中的变量一个用法 java中的变量你要和字符串连接起来,不也得用+连接吗?
我创建了一个存储过程,不过执行的时候报错,请教大神原因何在?
还有个次要问题,我的程序中用的是System.Data.OracleClient 但是OracleType中没有VARCHAR2,如何自己添加一个?
create or replace procedure customise(datefrom in varchar2, dateto in varchar2)
Authid Current_User as
vn_ctn number(2);
begin
select count(*) into vn_ctn from user_all_tables a where a.table_name like upper('customise1');
if vn_ctn > 0 then
execute immediate 'drop table customise1';
end if;
execute immediate 'create table customise1 as SELECT 关口点全名,电能量类型,数据 FROM 表底 WHERE datetime BETWEEN to_date(''datefrom'',''yyyy/mm/dd'') AND to_date(''dateto'',''yyyy/mm/dd'') and (电能量类型=''正向有功'' or 电能量类型=''反向有功'') GROUP BY 关口点全名,电能量类型,数据 HAVING COUNT(关口点全名)=trunc((To_date(''dateto'' , ''yyyy/mm/dd hh24-mi-ss'') - To_date(''datefrom'' , ''yyyy/mm/dd hh24-mi-ss'')+2))';
end ;
报错如下
*
第一行出现错误:
ORA-01841:(完整) 年份值必须介于 -4731 和 +9999 之间,且不为 0
ORA-06512: 在 "ORACLE.CUSTOMISE", line 9
OEA-06512: 在 line 1
------解决思路----------------------
楼主 datefrom 和 dateto传入参数在动态sql里面没有用到而是用一个字符串去to_date。。。
------解决思路----------------------
execute immediate 'create table customise1 as SELECT 关口点全名,电能量类型,数据 FROM 表底 WHERE datetime BETWEEN to_date('''
------解决思路----------------------
datefrom
------解决思路----------------------
''',''yyyy/mm/dd'') AND to_date('''
------解决思路----------------------
dateto
------解决思路----------------------
''',''yyyy/mm/dd'') and (电能量类型=''正向有功'' or 电能量类型=''反向有功'') GROUP BY 关口点全名,电能量类型,数据 HAVING COUNT(关口点全名)=trunc((To_date('''
------解决思路----------------------
dateto
------解决思路----------------------
''' , ''yyyy/mm/dd hh24-mi-ss'') - To_date('''
------解决思路----------------------
datefrom
------解决思路----------------------
''' , ''yyyy/mm/dd hh24-mi-ss'')+2))';
------解决思路----------------------
楼主啊,两个字符串怎么连接啊? 不是用
------解决思路----------------------
去连接吗
比如 “ab”
------解决思路----------------------
"cd"的结果就是“abcd”
但是你这个sql本身就用单引号引起来了 然后单引号内部 两个单引号被当成一个单引号去解析 所以你的datatime就被当成字符串 而不是变量了 这根java代码中的变量一个用法 java中的变量你要和字符串连接起来,不也得用+连接吗?