如何比较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. docker api 开发的端口怎么获取?2. angular.js - angularjs的自定义过滤器如何给文字加颜色?3. docker容器呢SSH为什么连不通呢?4. mac里的docker如何命令行开启呢?5. boot2docker无法启动6. debian - docker依赖的aufs-tools源码哪里可以找到啊?7. angular.js - angular内容过长展开收起效果8. dockerfile - 为什么docker容器启动不了?9. 在应用配置文件 app.php 中找不到’route_check_cache’配置项10. java - 为什么第一个线程已经释放了锁,第二个线程却不行?

网公网安备