时间函数java_Java时间函数整理

Java中涉及时间的类主要有Date, DateFormat(SimpleDateFormat), Calendar 。

(1)Date  时间类型,主要负责时间的存储和时间间隔的计算。 从属包 java.util

常用方法:

getTime() 返回自 1970 年 1 月 1 日 00:00:00 GMT 以来此Date 对象表示的毫秒数。

after(Date when) 测试此日期是否在指定日期之后。

before(Date when) 测试此日期是否在指定日期之前。

compareTo(Date anotherDate) 比较两个日期的顺序。当大于一个日期,返回1;等于返回0;小于返回-1。

(2)SimpleDateFormat 主要负责将时间转换成指定格式的字符串,及将指定格式的字符串转化成Date。 从属包 java.text

常用方法:

SimpleDateFormat(String pattern)  用给定的模式和默认语言环境的日期格式符号构造SimpleDateFormat。

parse(String source)           从给定字符串的开始解析文本,以生成一个日期。

format(Date date) 将一个 Date 格式化为日期/时间字符串。

(3)Calendar 主要负责时间的计算,获取指定的年,月,日等信息。 从属包 java.util

常用方法:

getInstance()返回Calendar实例对象

setTime(Date date) 使用给定的Date 设置此 Calendar 的时间。

get(int field)返回给定日历字段的值。可以Calendar.YEAR , Calendar.DAY_OF_MONTH 等获取指定的日期值。

getTime()返回操作后的日期。

add(int field, int amount) 根据日历的规则,为给定的日历字段添加或减去指定的时间量。

1 Date转String案例

package cjr.otherApi;

import java.text.DateFormat;

import java.text.SimpleDateFormat;

import java.util.Date;

public class DateDome {

public static void main(String[] args) {

Date date = new Date();

DateFormat df1 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");//2016-05-19 10:21:02

SimpleDateFormat df2 = new SimpleDateFormat("yyyy年MM月dd日 HH时mm分ss秒");//2016年05月19日 10时21分02秒

DateFormat df3 = new SimpleDateFormat("yyyy/MM/dd hh:mm:ss a");//2016/05/19 10:21:02 上午

DateFormat df4 = new SimpleDateFormat("yyyy-MM-dd");//2016-05-19

System.out.println(df1.format(date));

System.out.println(df2.format(date));

System.out.println(df3.format(date));

System.out.println(df4.format(date));

}

}

运行结果:

2016-05-19 10:21:02

2016年05月19日 10时21分02秒

2016/05/19 10:21:02 上午

2016-05-19

2 String转Date案例

package cjr.otherApi;

import java.text.DateFormat;

import java.text.ParseException;

import java.text.SimpleDateFormat;

import java.util.Date;

public class DateDome {

public static void main(String[] args) throws ParseException {

String strDate = "1990年10月01日 00时00分00秒";

DateFormat df = new SimpleDateFormat("yyyy年MM月dd日 HH时mm分ss秒");

Date date = df.parse(strDate);

Date now = new Date() ;

System.out.println(date.compareTo(now));

System.out.println(date.compareTo(date));

System.out.println(now.compareTo(date));

String strDate1 = "1990年10月1日";

DateFormat df1 = new SimpleDateFormat("yyyy年M月d日");

Date date1 = df.parse(strDate);

System.out.println(date);

System.out.println(date1);

}

}

运行结果:

-1

0

1

Mon Oct 01 00:00:00 CST 1990

Mon Oct 01 00:00:00 CST 1990

3 时间Calendar操作案例

package cjr.otherApi;

import java.util.Calendar;

import java.util.Date;

public class CalendarDemo {

public static void main(String[] args) {

Calendar cal = Calendar.getInstance();

cal.setTime(new Date());

//=============获取年月日等信息==================

int year = cal.get(Calendar.YEAR);

int month = cal.get(Calendar.MONTH);

int day =cal.get(Calendar.DAY_OF_MONTH);

System.out.println("现在时间是:"+year+"年"+month+"月"+day+"日");

//=============时间增减========================

cal.add(Calendar.DAY_OF_YEAR, 20);

System.out.println("20天后是:" + cal.get(Calendar.YEAR)+"年"+cal.get(Calendar.MONTH)+"月"+cal.get(Calendar.DAY_OF_MONTH)+"日");

cal.add(Calendar.DAY_OF_YEAR, -30);

System.out.println("10天前是:" + cal.get(Calendar.YEAR)+"年"+cal.get(Calendar.MONTH)+"月"+cal.get(Calendar.DAY_OF_MONTH)+"日");

}

}

运行结果:

现在时间是:2016年4月19日

20天后是:2016年5月8日

10天前是:2016年4月9日

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: InfluxDB是一款开源的分布式时序数据库,它支持数据聚合和函数计算,可以用来处理大量的时间序列数据。在Java,可以通过InfluxDB的Java API来实现聚合函数的使用。 以下是InfluxDB聚合函数Java的实用案例: 1. 查询最大值和最小值 使用InfluxDB的max()和min()函数可以查询一个时间段内某个字段的最大值和最小值。例如,查询CPU使用率的最大值和最小值: ```java QueryResult queryResult = influxDB.query(new Query("SELECT max(cpu), min(cpu) FROM cpu_usage WHERE time > now() - 1h")); ``` 2. 查询平均值 使用InfluxDB的mean()函数可以查询一个时间段内某个字段的平均值。例如,查询CPU使用率的平均值: ```java QueryResult queryResult = influxDB.query(new Query("SELECT mean(cpu) FROM cpu_usage WHERE time > now() - 1h")); ``` 3. 查询总和 使用InfluxDB的sum()函数可以查询一个时间段内某个字段的总和。例如,查询内存使用量的总和: ```java QueryResult queryResult = influxDB.query(new Query("SELECT sum(memory) FROM memory_usage WHERE time > now() - 1h")); ``` 4. 查询数量 使用InfluxDB的count()函数可以查询一个时间段内某个字段的数量。例如,查询请求次数的数量: ```java QueryResult queryResult = influxDB.query(new Query("SELECT count(requests) FROM request_log WHERE time > now() - 1h")); ``` 5. 查询百分比 使用InfluxDB的percentile()函数可以查询一个时间段内某个字段的百分比。例如,查询响应时间的90%百分位: ```java QueryResult queryResult = influxDB.query(new Query("SELECT percentile(response_time, 90) FROM response_log WHERE time > now() - 1h")); ``` 以上就是InfluxDB聚合函数Java的实用案例。使用这些函数可以方便地处理大量的时间序列数据,从而得到有用的信息和洞见。 ### 回答2: InfluxDB是一款开源的时间序列数据库,它支持聚合函数来对数据进行汇总和分析。对于JAVA程序员来说,使用InfluxDB的聚合函数能够实现一些实用的功能。 首先,可以使用聚合函数计算数据的平均值、最大值、最小值、总和等统计信息。这些统计信息可以帮助我们了解数据的整体趋势和特征,对于监控系统、日志分析等应用场景非常有用。例如,我们可以使用InfluxDB的聚合函数计算某个时间段内的平均CPU使用率、最高温度、最低湿度等信息。 其次,聚合函数还可以用于对时间序列数据进行分组。我们可以根据时间、标签、字段等维度将数据进行分组,然后对每个组内的数据进行聚合操作。这样可以更好地利用数据的结构特点,提取出某个时间段内不同标签或字段的统计信息。例如,我们可以按照城市对气温数据进行分组,并计算每个城市在不同时间段内的平均气温。 此外,聚合函数还可以用于填充缺失的数据。在时间序列数据,常常存在一些缺失值,但是我们在分析数据时往往需要连续的数据。可以使用InfluxDB的聚合函数来填充这些缺失的数据,可以使用插值、补零等方式来填充。这样可以保证数据的连续性,便于后续的分析和可视化展示。 总之,InfluxDB的聚合函数JAVA的应用非常广泛,可以帮助我们对时间序列数据进行统计分析、分组计算和数据填充等操作,为数据处理和分析提供了很大的便利性。 ### 回答3: InfluxDB 是一种开源的时序性数据库,被广泛应用于存储和检索大规模的时间序列数据。它提供了多种聚合函数来处理和分析大量的数据。下面是一些使用 InfluxDB 聚合函数Java 实用案例。 1. 查询平均值:通过使用聚合函数 MEAN,可以计算时间范围内数据的平均值。可以使用以下代码来实现: ``` InfluxDB influxDB = InfluxDBFactory.connect("http://localhost:8086", "username", "password"); Query query = new Query("SELECT MEAN(value) FROM measurement WHERE time > now() - 1h", "database"); QueryResult queryResult = influxDB.query(query); ``` 2. 查询最大值和最小值:通过使用聚合函数 MAX 和 MIN,可以计算时间范围内数据的最大值和最小值。可以使用以下代码来实现: ``` Query query = new Query("SELECT MAX(value), MIN(value) FROM measurement WHERE time > now() - 1d", "database"); QueryResult queryResult = influxDB.query(query); ``` 3. 查询统计信息:通过使用聚合函数 COUNT、SUM、MEAN、MAX 和 MIN,可以计算时间范围内数据的计数、总和、平均值、最大值和最小值。可以使用以下代码来实现: ``` Query query = new Query("SELECT COUNT(value), SUM(value), MEAN(value), MAX(value), MIN(value) FROM measurement WHERE time > now() - 1w", "database"); QueryResult queryResult = influxDB.query(query); ``` 4. 查询数据分组:通过使用聚合函数 GROUP BY,可以将数据按照某个字段进行分组。可以使用以下代码来实现: ``` Query query = new Query("SELECT MEAN(value) FROM measurement WHERE time > now() - 1h GROUP BY tag", "database"); QueryResult queryResult = influxDB.query(query); ``` 以上是一些使用 InfluxDB 聚合函数Java 实用案例,可以根据具体需求进行调整和扩展。通过使用这些聚合函数,可以方便地对大规模的时间序列数据进行处理和分析,提取有用的信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值