java 中 日期如何相加减???

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java 中 日期如何相加减???相关的知识,希望对你有一定的参考价值。

比如 现在的时间是 2012-05-01 12:30:05
然后还有一个时间是 2011-04-01 02:19:22
如何计算两个时间的差值?

这个东西很简单。
现在是2004-03-26 13:31:40
过去是:2004-01-02 11:30:24
要获得两个日期差,差的形式为:XX天XX小时XX分XX秒

方法一:
DateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

try

Date d1 = df.parse("2004-03-26 13:31:40");
Date d2 = df.parse("2004-01-02 11:30:24");
long diff = d1.getTime() - d2.getTime();
long days = diff / (1000 * 60 * 60 * 24);

catch (Exception e)



方法二:
SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
java.util.Date now = df.parse("2004-03-26 13:31:40");
java.util.Date date=df.parse("2004-01-02 11:30:24");
long l=now.getTime()-date.getTime();
long day=l/(24*60*60*1000);
long hour=(l/(60*60*1000)-day*24);
long min=((l/(60*1000))-day*24*60-hour*60);
long s=(l/1000-day*24*60*60-hour*60*60-min*60);
System.out.println(""+day+"天"+hour+"小时"+min+"分"+s+"秒");

方法三:
SimpleDateFormat dfs = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
java.util.Date begin=dfs.parse("2004-01-02 11:30:24");
java.util.Date end = dfs.parse("2004-03-26 13:31:40");
long between=(end.getTime()-begin.getTime())/1000;//除以1000是为了转换成秒

long day1=between/(24*3600);
long hour1=between%(24*3600)/3600;
long minute1=between%3600/60;
long second1=between%60/60;
System.out.println(""+day1+"天"+hour1+"小时"+minute1+"分"+second1+"秒");
参考技术A Date类的getTime()方法返回long型,单位时毫秒。因此对两个Date调用getTime()方法后相减并除以相应数字换算单位即可。 参考技术B /**
* 时间比较.
*
* @param start
* @param end
* @return
*/
public static long compdate(String start, String end)
DateFormat dateformat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
long result = 0;
try
Date dstart = dateformat.parse(start);
Date dend = dateformat.parse(end);
long lstart = dstart.getTime();
long lend = dend.getTime();
result = (lend - lstart) / 1000 / 1800;
catch (ParseException e)
// TODO Auto-generated catch block
e.printStackTrace();
return -1;

return result;
参考技术C //返回毫秒数
public static long getDiffTime(Date startDate, Date endDate)
return endDate.getTime() - startDate.getTime();

js 中处理时间相加减问题

之前需求是当前时间+5天,写法如下

1 var dataCur = new Date(); //当前日期
2 var dataDef = dataCur.getFullYear() + ‘-‘ + (dataCur.getMonth() + 1) + ‘-‘ + (dataCur.getDate() + 5)

但这种写法有个问题,就是月末比如今天 3.28 + 5天,就成 3.33号(么有这个日期)

 

于是换了种写法,先将时间转成时间戳,将时间戳+5天(86400 * 5),就不会有这种问题,写法如下:

1 //时间默认值,默认当前时间+5天
2     var dataCur = new Date(); //当前日期
3     dataCur = dataCur.getFullYear() + ‘-‘ + (dataCur.getMonth() + 1) + ‘-‘ + dataCur.getDate() + " 00:00:00";
4     var dataCurPar = Date.parse(new Date(dataCur))/1000;//转换为时间戳
5     dataCurPar += 86400 * 5;//加5天后的时间戳
6     var dataDefPar = new Date(parseInt(dataCurPar) * 1000);//转换为时间
7     var dataDef = dataDefPar.getFullYear() + ‘-‘ + (dataDefPar.getMonth() + 1) + ‘-‘ + (dataDefPar.getDate());

 

以上是关于java 中 日期如何相加减???的主要内容,如果未能解决你的问题,请参考以下文章

java或Jmeter实现两个日期相加减(2003-06-01-2003-05-01)

javaScript日期相加减例子

sql语句怎么来对日期进行相加减

js 中处理时间相加减问题

SQL中怎么实现时间相加。比如 我要实现 从今天的日期加30天为到期日。

mysql触发器使日期相加减?