如何比较java中的Date与mysql中datetime类型的字段?
问题描述
现在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.
相关文章:
1. javascript - 百度echarts series数据更新问题2. Mysql && Redis 并发问题3. css3 - css before 中文乱码?4. php - 第三方支付平台在很短时间内多次异步通知,订单多次确认收款5. javascript - 请问一下组件的生命周期beforeDestory是在什么情况下面触发的呢?6. mysql - 一个表和多个表是多对多的关系,该怎么设计7. javascript - 请教空白文本节点的问题8. javascript - 父选项卡bug,子选项卡好用,求解?9. javascript - node服务端渲染的困惑10. mysql新建字段时 timestamp NOT NULL DEFAULT ’0000-00-00 00:00:00’ 报错
