17,380
社区成员
发帖
与我相关
我的任务
分享
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
[/quote]
楼主啊,两个字符串怎么连接啊? 不是用||去连接吗
比如 “ab”||"cd"的结果就是“abcd”
但是你这个sql本身就用单引号引起来了 然后单引号内部 两个单引号被当成一个单引号去解析 所以你的datatime就被当成字符串 而不是变量了 这根java代码中的变量一个用法 java中的变量你要和字符串连接起来,不也得用+连接吗?
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))';