如何比较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 - webpack 多入口文件生成HTML文件;2. docker安装后出现Cannot connect to the Docker daemon.3. nignx - docker内nginx 80端口被占用4. node.js - mongoDB使用$gte的问题5. 计算机 - 我学习了C语言,数据结构和一点点java基础,想自学C++,请问买什么入门书籍好?6. java中关于直接插入排序遇到的问题。7. java - 如图,jsp页面的form中的action是怎么映射到这个位置的?为什么不写dynUser就可以映射到save?8. javascript - npm run build后调用api返回index.html9. docker绑定了nginx端口 外部访问不到10. 我在centos容器里安装docker,也就是在容器里安装容器,报错了?
