您的位置:首页技术文章
文章详情页

如何比较java中的Date与mysql中datetime类型的字段?

浏览:44日期:2024-01-01 09:40:27

问题描述

现在mysql数据库db有一张表test(id bigint,createTime datetime),部分表数据如下:

idcreateTime12017-01-02 10:34:3322017-01-05 11:35:3132017-01-07 13:20:0142017-01-13 10:06:3352017-01-15 11:22:5362017-01-20 10:34:3372017-01-25 10:46:25

现在要通过java代码拼接sql字符串的形式查出所有创建时间在2017-01-15 00:00:00之后的数据。

限定 : 通过以下两种方式查询

第一种 :拼接字符串

String sql = 'select id,createTime from db.test where createTime > ' + javaCreateTime

第二种 : 预编译的形式传入查询参数:

String sql = 'select id,createTime from db.test where createTime > ?'

请问 : 第一种方式的javaCreateTime应该怎么传?第二种预编译的方式参数又应该怎么传?

从网上找到解决的办法了:

第一种传入:

String sql = 'select id,createTime from db.test where createTime > ’2017-01-15 00:00:00’ '

第二种

String sql = 'select id,createTime from db.test where createTime > ? ';PreparedStatement preStat = connection.prepareStatement(sql);preStat.setString(1, ’2017-01-15 00:00:00’);ResultSet rs = preStat.executeQuery();

以上两种方式都是直接传入字符串,而且都是yyyy-MM-dd HH:mm:ss。请问为什么可以达到目的?mysql会自动将字符串转化为datetime?。其底层运行机制到底是什么原因呢?

问题解答

回答1:

mysql会自动将字符串转化为datetime?

這要看你將它們加入表的時候,它們本身的datatype是不是datetime

又或者是它們在mysql的column可能已經set成datetime

你可以打 desc test;查看

另外 2017-01-15 00:00:00 本身的格式已經是 datetime.

标签: java
相关文章: