用PreparedStatement在Oracle中插入日期
2008-04-09 17:14
435 查看
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);
......
结果如下:
建表时,将字段默认值声明为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);
......
结果如下:
相关文章推荐
- java向ORACLE插入日期时间
- JDBC用PreparedStatement在Oracle中插入日期
- 在Oracle使用sql语句中如何插入日期格式的数据
- mysql插入日期 vs oracle插入日期
- oracle_日期维度表插入数据
- java将日期时间字符串转成日期插入到oracle的date字段
- oracle 插入日期的方式
- 如何向 Oracle 表中的 Date 字段插入日期及时间
- mysql插入日期 vs oracle插入日期
- 如何向 Oracle 表中的 Date 字段插入日期及时间
- 用PreparedStatement在Oracle中插入日期
- oracle日期的插入操作
- java解析oracle日志,获取指定日期后的更新和插入数据
- Oracle date 插入显示公元前日期
- java向oracle插入日期类型部分代码
- oracle插入日期to_date转换函数
- oracle日期的查询和插入
- Oracle中插入日期数据
- 在Oracle中插入日期类型的数据
- 用PreparedStatement在Oracle中插入日期