从PHP代码调用时,Oracle insert语句不起作用

时间:2016-07-07 14:06:57

标签: php sql oracle stored-procedures oci

我的Oracle 12c数据库中有一个存储过程,它删除表中的所有数据,然后将新数据插入到同一个表中。从SQL Developer调用时,存储过程按预期工作,但是,当我使用PHP代码调用该过程时,它只执行" delete"声明,但不是插入。

我的存储过程:

create or replace procedure myProcedure(
returnResult out varchar2
)
is
inc number;
current_day date;
begin

inc := 0;
select to_date(sysdate, 'yyyy.mm.dd') into current_day from dual;

delete from TEMP_GRAFIKAI;
commit;

while inc < 10
loop
insert into TEMP_GRAFIKAI (NUO, IKI, JUST_DATE, NUO_TIME, IKI_TIME, STAFF_ID, STUN_ID, PROFESSION_ID, PLACE_ID)
with t as (select /*+ materialize */ min(a.SCHEDULE_TIME) NUO, 
max(a.SCHEDULE_TIME) IKI,
to_char(min(a.SCHEDULE_TIME), 'yyyy.mm.dd') JUST_DATE , 
to_char(min(a.SCHEDULE_TIME), 'hh24:mi') NUO_TIME, 
to_char(max(a.SCHEDULE_TIME), 'hh24:mi') IKI_TIME,
b.ID STAFF_ID, e.ID STUN_ID, d.PROFESSION_ID, f.PLACE_ID
from SCHEDULE_TIME a
join STAFF b on a.TREATMENT_STAFF_ID = b.ID
join COMPANY_PERSON c on c.STAFF_ID = b.ID and c.COMPANY_ID = 1 and c.STRUCTURE_UNIT_ID != 1
join PROFESSION_TEXT d on a.TREATMENT_PROF_ID = d.PROFESSION_ID and d.LANG_DOVA_CODE = 'lt'
join ORGANIZATION e on a.TREATMENT_STUN_ID = e.ID
join PLACE_TEXT f on a.TREATMENT_PLACE_ID = f.PLACE_ID and f.LANG_DOVA_CODE = 'lt'
join SCHEDULES g on a.SCHEDULE_ID = g.ID and g.SYS_DELETE_STATUS = 'N'
where a.SCHEDULE_TIME > current_day+inc and a.SCHEDULE_TIME < current_day+1+inc
and a.SYS_DELETE_STATUS = 'N'
group by b.ID, e.ID, d.PROFESSION_ID, f.PLACE_ID)
select t.NUO, t.IKI, t.JUST_DATE, t.NUO_TIME, t.IKI_TIME, t.STAFF_ID, t.STUN_ID, t.PROFESSION_ID, t.PLACE_ID from t
;
commit;
inc := inc +1;
returnResult:= 'in_loop'||to_char(inc);
end loop;

if returnResult != 'in_loop10' then
returnResult := 'ok';
end if;

end;

使用&#34; in_loop&#34;第一部分我正在检查循环是否实际上是循环的,发现没有问题,它正确地循环循环10次。

我的PHP代码:

$dbhandle = oci_connect($user, $password, $host, "AL32UTF8");

$proc = oci_parse($dbhandle, "call myProcedure(:returnResult)");
oci_bind_by_name($proc, ":returnResult", $returnResult, 50);
$result = oci_execute($proc);

if (!$result) {$e = oci_error($proc); $err = 'err:'.$e["message"];}

$ result不会抛出任何错误,$ returnResult正确返回文本字符串&#34; in_loop10&#34;。

执行删除语句没有任何问题,但插入部分不会插入任何内容。 如果我从SQL Developer执行相同的存储过程,那么所有(删除和插入)都可以正常工作。

我认为问题可能在insert语句中,特别是&#34;实现&#34;部分,但我不完全确定。

我在这里不知所措,不知道为什么当我从PHP代码调用过程时插入部分不起作用。任何帮助将不胜感激。

1 个答案:

答案 0 :(得分:1)

如果我不得不猜测,那是因为

select to_date(sysdate, 'yyyy.mm.dd') into current_day from dual;

您看,sysdate已有date类型。使用此行,您将使用连接默认NLS设置隐式将其转换为varchar2,然后将其转换回日期。如果PHP连接yyyy.mm.dd以外的NLS日期设置,则在尝试转换回来时,您将获得异常(不是这种情况)或错误的日期。如果您只想要一个没有时间的日期部分,请改用trunc(sysdate)。此外,您只需分配给变量:current_day := trunc(sysdate);

如果这不起作用,请尝试直接从PHP运行select,也许由于配置不同或其他原因,它实际上不会在该连接下返回任何结果。