Welcome 微信登录

首页 / 数据库 / MySQL / 用PreparedStatement在Oracle中插入日期

1、 如果要插入的日期是当前时间,最简单的办法就是利用Oracle自带的日期函数:sysdate。
建表时,将字段默认值声明为sysdate,如下:
create table examples

     names varchar(10 ),
     age    number(3 ),
     BirDate date    default sysdate

执行insert时,只需要insert前两个字段,BirDate字段会自动用当前时间填充,如下:
insert into examples(names,age) values("helo",25);
执行结果如下:


这种方法的缺点是不够灵活。

2、 如果要插入的日期只是年月日,则可以使用PreparedStatement的setDate()方法,改方法接受两个参数,第一个是插入的字段序列,第二个是java.sql.DATE类型的日期。
设表结构如下:
create table examples

     names varchar(10 ),
     age    number(3 ),
     BirDate date  


则先获得日期:
    java.util.Date utilDate = new java.util.Date();
   // Convert it to java.sql.Date
   java.sql.Date date = new java.sql.Date( utilDate .getTime());

PreparedStatement psmt = null;
String sqlstr = "insert into examples values(?,?,?)";
   ....
psmt.setDate(3,date);
psmt.executeUpdate();

结果如下:


3、 如果插入的时间要精确到秒,则可以使用PreparedStatement的setTimestamp()方法,该方法接受两个参数:setTimestamp(int parameterIndex,Timestamp x),
表结构同上,
获得一个Timestamp:
        java.util.Date Dates = new java.util.Date();
        java.sql.Timestamp time = new java.sql.Timestamp(Dates.getTime());
        ......
       psmt.setTimestamp(3, time);
        ......
结果如下:

Linux下安装完MySQL后找不到my.cnf文件原因Oracle 10g 对 Linux 系统的基本需求相关资讯      oracle 
  • [INS-32052] Oracle基目录和Oracle  (07/22/2014 07:41:41)
  • Oracle 4个大对象(lobs)数据类型  (02/03/2013 12:33:05)
  • Oracle按时间段分组统计  (07/26/2012 10:36:48)
  • [Oracle] dbms_metadata.get_ddl的  (07/12/2013 07:37:30)
  • Liferay Portal 配置使用Oracle和  (07/31/2012 20:07:18)
  • Concurrent Request:Inactive   (07/20/2012 07:44:05)
本文评论 查看全部评论 (2)
表情: 姓名: 字数


评论声明
  • 尊重网上道德,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或删除其管辖留言中的任意内容
  • 本站有权在网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款