首页 > 数据库技术 > 详细

oracle 存储过程中使用date 时、分、秒丢失

时间:2014-07-19 08:23:09      阅读:573      评论:0      收藏:0      [点我收藏+]

   今天有一开发兄弟找我,说出现一奇怪现象,在存储过程中赋date类型的值,时、分、秒都丢失了,下面来做个试验:

SQL> drop table test purge;

SQL> create table test
    (
     fill_date  date
    );
SQL> insert into test values(sysdate);
SQL> commit;
SQL> select to_char(fill_date,‘yyyy-MM-dd HH24:mi:ss‘) from test;
TO_CHAR(FILL_DATE,‘
-------------------

2014-07-18 17:47:22

SQL> CREATE OR REPLACE PROCEDURE test_p
is
s_sql varchar2(500);
s_date date;
begin
s_date:= to_date(‘2014-07-18 17:24:32‘,‘yyyy-MM-dd HH24:mi:ss‘);
s_sql := ‘UPDATE test SET fill_date = ‘‘‘||s_date ||‘‘‘‘;
execute immediate s_sql;
commit;
end;

/

SQL> call test_p();

SQL> select to_char(fill_date,‘yyyy-MM-dd HH24:mi:ss‘) from test;
TO_CHAR(FILL_DATE,‘
-------------------
2014-07-18 00:00:00     --可以看到确实时、分、秒已经丢失,怀疑是隐式转换导致

--调整下存储过程,看打印出什么来。

SQL> CREATE OR REPLACE PROCEDURE test_p
is
s_sql varchar2(500);
s_date date;
begin
s_date:= to_date(‘2014-07-18 17:24:32‘,‘yyyy-MM-dd HH24:mi:ss‘);
s_sql := ‘UPDATE test SET fill_date = ‘‘‘||s_date ||‘‘‘‘;
dbms_output.put_line(s_sql);
execute immediate s_sql;
commit;
end;

/

SQL> set serveroutput on

SQL> call test_p();
UPDATE test SET fill_date = ‘18-7月 -14‘
调用完成。

--确认发生了隐式转换,那就使用绑定变量了

SQL> CREATE OR REPLACE PROCEDURE test_p
is
s_sql varchar2(500);
s_date date;
begin
s_date:= to_date(‘2014-07-18 17:24:32‘,‘yyyy-MM-dd HH24:mi:ss‘);
s_sql := ‘UPDATE test SET fill_date = :1‘;
execute immediate s_sql using s_date;
commit;
end;

/

SQL> call test_p();
调用完成。

SQL> select to_char(fill_date,‘yyyy-MM-dd HH24:mi:ss‘) from test;
TO_CHAR(FILL_DATE,‘
-------------------
2014-07-18 17:24:32

oracle 存储过程中使用date 时、分、秒丢失,布布扣,bubuko.com

oracle 存储过程中使用date 时、分、秒丢失

原文:http://blog.csdn.net/stevendbaguo/article/details/37934785

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!