Mysql数据库的时间(4)一查询比较数据库时间注意点

一.select比较时间大小

直接传java的时间类型参数查询   (各种传参注意点详见桌面excel时间表)

情况一:两个比较的时间格式一样

1.要保证连个比较的时间的格式最好是推荐是保持一致的.

1.如果两个比较的时间格式一样,那么就可以直接比较.

2.如果不一样,那么就用date_format把数据库的时间格式转换下,变成一样的,再去比较

比如:想查出数据库每天14点到23点的数据的sql写法如下:

SELECT * FROM `utime` where DATE_FORMAT(insertTime ,"%H:%i:%S") BETWEEN "14:01:01" and  "23:12:12";

情况二:两个比较的时间格式不一样,比大小

那么缺少的时间会被填充1970.01.01  00.00.00

比如:

SELECT * FROM `stu` where insertTime > '2023-05-02'    

缺失的时分秒会被填充为 00.00.00 , 也就是说上面的sql其实会变成下面的sql再去比较

SELECT * FROM `stu` where insertTime > '2023-05-02  00:00:00'  

下面是查询结果:

情况三:两个比较的时间格式不一样,比相等

那么缺少的时间也会被填充1970.01.01  00.00.00

比如:

SELECT * FROM `stu` WHERE insertTime = '2023-04-02'

缺失的时分秒会被填充为 00.00.00 , 也就是说上面的sql其实会变成下面的sql再去比较

SELECT * FROM `stu` WHERE insertTime = '2023-04-02 00:00:00'

下面是查询结果: 

因为没有时间等于'2023-04-02 00:00:00'  ,所以什么也查不到

二.select查询时间字段

 1.在sql语句用date_format()函数中转换格式

具体实现和注意点详见我的扩展笔记--和excel时间表格

如果是java用string接收数据库返回的时间字段,那么sql中可以用date_format()定义好时间格式.

Select DATE_FORMAT(`Deadline`, "%y-%m-%d %H:%i:%s") as deadline From table

2.select查询时间字段后java用什么类型去接.

详见时间excel时间表格

注意:接收不到的字段就会默认填充1970.01.01 00.00.00

如:用java.sql.date去接收数据库的year, java.sql.date的类型是YYYY-MM-DD,而year是YYYY,那么MM-DD就会被默认填充为01-01. 例如2023会被默认填充为2023-01-01

数据库时间类型

sql查出来后返回到后端的初始格式

(就是用object去接收,没有经过任何格式处理)

java可接收类型
date

2003-02-19

除了数值类型,如Double, 其他什么时间类型都能接
time

10:47:59

除了数值类型,如Double, 其他什么时间类型都能接
datetime

2003-02-19T13:48:02

除了数值类型,如Double, 其他什么时间类型都能接
timestamp

2003-02-19 13:48:05.0

除了数值类型,如Double, 其他什么时间类型都能接
year

2003-01-01

除了数值类型,如Double, 其他什么时间类型都能接

 3.从数据库查出来成功接收到时间字段后,通过代码去修改格式

详见B站笔记

比如,用java.util.date接收到了查询数据库返回的时间字段,这时,java.util.date的时间格式是Mon Mar 14 11:08:25 GMT+08:00 2022

我们可以通过new  SimpleDateFormat 去改变时间格式, 如下:

String timeStamp = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date());
System.out.println(timeStamp);

4.用@JsonFormat注解和@DataFormat去转换格式并返回给前端 (没吊用)

详情注意内容请看扩展笔记

public class ClassA{
    private String itemCode;
    @DateTimeFormat(pattern = "yyyy-MM-dd")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone="GMT+8")
    private Date deadline;
}

注解@JsonFormat主要是后台到前台的时间格式的转换     详情注意内容请看扩展笔记

注解@DataFormat主要是前后到后台的时间格式的转换(完全没用!)详情注意内容请看扩展笔记

pattern:是你需要转换的时间日期的格式
timezone:是时间设置为东八区,避免时间在转换中有误差
提示:@JsonFormat注解可以在属性的上方,同样可以在属性对应的get方法上,两种方式没有区别


建议将日期格式转换及日期操作的独立写个工具类,也可以慢慢收集遇到不错的日期工具类

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值