如何实现String型时间加一天和减一天
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何实现String型时间加一天和减一天相关的知识,希望对你有一定的参考价值。
参考技术A import java.text.ParseException;import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;02public class TestTime
public static void main(String[] args)
String d = "2004-1-1";
DateFormat df = new SimpleDateFormat("yyyy-MM-dd");/*** 加一天*/try Date dd = df.parse(d);
Calendar calendar = Calendar.getInstance();
calendar.setTime(dd);
calendar.add(Calendar.DAY_OF_MONTH, 1);//加一天
System.out.println("增加一天之后:" + df.format(calendar.getTime()));
catch (ParseException e)
e.printStackTrace();02/*** 减一天*/try long dif = df.parse(d).getTime()-86400*1000;//减一天
02 02 02 02Date date=new Date();02
02 02 02 02date.setTime(dif);
02 02 02 02System.out.println("减少一天之后:" + df.format(date));
catch (ParseException e)
e.printStackTrace();02 02 02 02 02 020202输出地结果:
calendar.roll(Calendar.DAY_OF_MONTH, 1);//加一天
calendar.roll(Calendar.DAY_OF_MONTH, -1);//减一天一定不要用这个方法,经试验加一天的没问题,减一天的会出现一下问题:当时间为“2013-2-1”时,calendar.roll(Calendar.DAY_OF_MONTH, -1)得到结果的是“2013-2-28”,即这个月的月末一天,换句话说他只能够更改“yyyy-MM-dd”中的“dd”。api的解释是:向指定日历字段添加指定(有符号的)时间量,
不更改更大的字段
。负的时间量意味着向下滚动。
MySQL 日期自动加1天和减1天
1、给当前日期加一天
-- pre_etl_date和etl_date 均为字符串类型 UPDATE ETL_DATA SET pre_etl_date=DATE_FORMAT(STR_TO_DATE(etl_date,‘%y%m%d‘),‘%y%m%d‘),etl_date=DATE_FORMAT(DATE_ADD(etl_date,INTERVAL 1 DAY),‘%y%m%d‘);
2、给当前日期减一天
-- pre_etl_date和etl_date 均为字符串类型 UPDATE ETL_DATA SET pre_etl_date=DATE_FORMAT(STR_TO_DATE(etl_date,‘%y%m%d‘),‘%y%m%d‘),etl_date=DATE_FORMAT(DATE_SUB(etl_date,INTERVAL 1 DAY),‘%y%m%d‘);
以上是关于如何实现String型时间加一天和减一天的主要内容,如果未能解决你的问题,请参考以下文章