服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Java教程 - Java查询时间段(startTime--endTime)间的数据方式

Java查询时间段(startTime--endTime)间的数据方式

2022-08-16 09:16墨咖 Java教程

这篇文章主要介绍了Java查询时间段(startTime--endTime)间的数据方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

Java查询时间段的数据

问题1

判断时间间隔间的数据,就像查询数字一样通过between-and方法进行?

答1:

between-and用于查询数字区间,不用于查询两个时间间隔的内容。非要查询,可以试着把时间格式转换成Long型。

问题2

在用postman工具测试后,Java中报异常:(String类型和Date类型比较出现异常)?

异常信息:

### Error querying database.  Cause: java.lang.IllegalArgumentException: invalid comparison: java.util.Date and java.lang.String
### Cause: java.lang.IllegalArgumentException: invalid comparison: java.util.Date and java.lang.String

mybatis--xml

?
1
2
3
<if test="startTime != null and startTime != ''">
   AND create_time <![CDATA[>=]]> #{startTime}
</if>

答2:

此处的String类型和Date类型比较异常原因:if标签中,Date类型不存在String类型,直接判断就好

?
1
2
3
<if test="startTime != null">
 AND create_time <![CDATA[>=]]> #{startTime}
</if>

此时上述问题解决。

补充:

完整的时间区间比较代码

?
1
2
3
4
5
6
7
8
<where>
   <if test="startTime != null">
       AND create_time <![CDATA[>=]]> #{startTime}
   </if>
   <if test="endTime != null">
       AND create_time <![CDATA[<=]]>#{endTime}
   </if>
</where>

实体类

?
1
2
3
4
5
6
7
8
//创建时间
    private Date createTime;
 
//起始时间
    private Date startTime;
 
//结束时间
    private Date endTime;

格式化时间startTime和endTime的时间差

格式化时间startTime和endTime的 时间差,当间隔超过一年时,显示年月日;

超过一天时,显示月日;

超过一小时时,显示多少小时前;

超过一分钟时,显示多少分钟前;

不超过一分钟,则显示为刚刚

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
/**
 * 格式化时间startTime和endTime的 时间差,用于朋友圈等地方显示发布时间。例如“45分前”等
 * @param endTime :发布时间
 * @return 格式化的时间显示字符
 */
public static String getFriendlyTime(Date startTime, Date endTime) {
    long betweenTime = (endTime.getTime() - startTime.getTime()) / 1000;
    if (betweenTime < 0) {
        return DateTimeUtils.convertDate2String(startTime, "yyyy年MM月dd日");
    }
    if (betweenTime / (60 * 60 * 24 * 365) > 0) {
        //大于1年
        return DateTimeUtils.convertDate2String(startTime, "yyyy年MM月dd日");
    }
    if (betweenTime / (60 * 60 * 24 ) > 0) {
        //大于一天
        return DateTimeUtils.convertDate2String(startTime, "MM月dd日");
    }
    if (betweenTime / (60 * 60) > 0) {
        //大于1小时
        return betweenTime / (60 * 60) + "小时前";
    }
    if (betweenTime / (60) > 0) {
        //大于一分钟
        return betweenTime / (60) + "分钟前";
    }
    //小于一分钟
    return "刚刚";
}

以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/qq_37335810/article/details/83548011

延伸 · 阅读

精彩推荐
  • Java教程Java中二叉树数据结构的实现示例

    Java中二叉树数据结构的实现示例

    这篇文章主要介绍了Java中二叉树数据结构的实现示例,包括前中后序遍历和求二叉树深度的方法,需要的朋友可以参考下 ...

    zinss269142312020-01-02
  • Java教程Spring jdbc具名参数使用方法详解

    Spring jdbc具名参数使用方法详解

    这篇文章主要介绍了Spring jdbc具名参数使用方法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参...

    悄悄成长5472020-08-13
  • Java教程java发送短信的实现步骤

    java发送短信的实现步骤

    下面小编就为大家带来一篇java发送短信的实现步骤。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    lsyBlog6772021-01-10
  • Java教程Java中的显示锁ReentrantLock使用与原理详解

    Java中的显示锁ReentrantLock使用与原理详解

    这篇文章主要介绍了Java中的显示锁ReentrantLock使用与原理详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    爬蜥4422021-06-17
  • Java教程详解Spring MVC CORS 跨域

    详解Spring MVC CORS 跨域

    本篇文章主要介绍了详解Spring MVC CORS 跨域 ,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    小新是也3692020-11-03
  • Java教程java 浅析代码块的由来及用法

    java 浅析代码块的由来及用法

    所谓代码块是指用"{}"括起来的一段代码,根据其位置和声明的不同,可以分为普通代码块、构造块、静态块、和同步代码块。如果在代码块前加上 synchro...

    做哈白日梦4082022-02-25
  • Java教程Java TimedCache 带时间缓存工具类详解使用

    Java TimedCache 带时间缓存工具类详解使用

    工具类是包含集合框架、遗留的 collection 类、事件模型、日期和时间设施、国际化和各种实用工具类(字符串标记生成器、随机数生成器和位数组、日期...

    剑客阿良_ALiang7502022-03-03
  • Java教程java stringbuffer的用法示例

    java stringbuffer的用法示例

    这篇文章主要介绍了java stringbuffer的用法示例,字符串缓冲区,是一个容器(当返回到的是String时而且长度不确定,数据类型不确定时就可以用StringBuffer)其...

    java教程网2102019-10-31