如何比较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下的nginx压力测试2. javascript - nidejs环境设置操作一直出现这种问题怎么解决?3. angular.js - Ionic 集成crosswalk后生成的apk在android4.4.2上安装失败???4. 为什么我ping不通我的docker容器呢???5. javascript - 文件改后缀后怎么获得原来是什么类型的6. javascript - Angular controlller控制域和原生js的关系7. python - pandas按照列A和列B分组,将列C求平均数,怎样才能生成一个列A,B,C的dataframe8. dockerfile - [docker build image失败- npm install]9. java - 静态属性中的赋值和静态代码块中的赋值有什么区别?10. java - Tomcat 不同的域名访问同一个项目的不同网页
