java datediff_JAVA中的时间操作(附DATEDIFF函数用法)
http://blog.csdn.net/lujiancs/article/details/7043760
//字符串转化成时间类型(字符串可以是任意类型,只要和SimpleDateFormat中的格式一致即可)
java.text.SimpleDateFormat sdf = new java.text.SimpleDateFormat("M/dd/yyyy hh:mm:ss a",java.util.Locale.US);
java.util.Date d = sdf.parse("5/13/2003 10:31:37 AM");
out.println(d);
out.println("
");
SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
String mDateTime1=formatter.format(d);
out.println(mDateTime1);
out.println("
");
out.println(d.getTime());
out.println("
");
//当前时间
Calendar cal = Calendar.getInstance();
// SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss G E D F w W a E F");
String mDateTime=formatter.format(cal.getTime());
out.println(mDateTime);
out.println("
");
//1年前日期
java.util.Date myDate=new java.util.Date();
long myTime=(myDate.getTime()/1000)-60*60*24*365;
myDate.setTime(myTime*1000);
String mDate=formatter.format(myDate);
out.println(mDate);
out.println("
");
//明天日期
myDate=new java.util.Date();
myTime=(myDate.getTime()/1000)+60*60*24;
myDate.setTime(myTime*1000);
mDate=formatter.format(myDate);
out.println(mDate);
out.println("
");
//两个时间之间的天数
SimpleDateFormat myFormatter = new SimpleDateFormat("yyyy-MM-dd");
java.util.Date date= myFormatter.parse("2003-05-1");
java.util.Date mydate= myFormatter.parse("1899-12-30");
long day=(date.getTime()-mydate.getTime())/(24*60*60*1000);
out.println(day);
out.println("
");
//加半小时
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
java.util.Date date1 = format.parse("2002-02-28 23:16:00");
long Time=(date1.getTime()/1000)+60*30;
date1.setTime(Time*1000);
String mydate1=formatter.format(date1);
out.println(mydate1);
out.println("
");
//年月周求日期
SimpleDateFormat formatter2 = new SimpleDateFormat("yyyy-MM F E");
java.util.Date date2= formatter2.parse("2003-05 5 星期五");
SimpleDateFormat formatter3 = new SimpleDateFormat("yyyy-MM-dd");
String mydate2=formatter3.format(date2);
out.println(mydate2);
out.println("
");
//求是星期几
mydate= myFormatter.parse("2001-1-1");
SimpleDateFormat formatter4 = new SimpleDateFormat("E");
String mydate3=formatter4.format(mydate);
out.println(mydate3);
out.println("
");
%>
附:DATEDIFF 函数
DATEDIFF 函数
返回 VARIANT (LONG) 的值,表示两个指定日期间的时间间隔数目。
语法
DATEDIFF(INTERVAL, DATE1, DATE2[, FIRSTDAYOFWEEK][, FIRSTWEEKOFYEAR]])
DATEDIFF 函数语法中有下列命名参数:
部分 描述
INTERVAL 必要。字符串表达式,表示用来计算DATE1 和 DATE2 的时间差的时间间隔
DATE1□DATE2 必要;VARIANT (DATE)。计算中要用到的两个日期。
FIRSTDAYOFWEEK 可选。指定一个星期的第一天的常数。如果未予指定,则以星期日为第一天。
FIRSTWEEKOFYEAR 可选。指定一年的第一周的常数。如果未予指定,则以包含 1 月 1 日的星期为第一周。
设置
INTERVAL 参数的设定值如下:
设置 描述
YYYY 年
Q 季
M 月
Y 一年的日数
D 日
W 一周的日数
WW 周
H 时
N 分钟
S 秒
FIRSTDAYOFWEEK 参数的设定值如下:
常数 值 描述
VBUSESYSTEM 0 使用 NLS API 设置。
VBSUNDAY 1 星期日(缺省值)
VBMONDAY 2 星期一
VBTUESDAY 3 星期二
VBWEDNESDAY 4 星期三
VBTHURSDAY 5 星期四
VBFRIDAY 6 星期五
VBSATURDAY 7 星期六
常数 值 描述
VBUSESYSTEM 0 用 NLS API 设置。
VBFIRSTJAN1 1 从包含 1 月 1 日的星期开始(缺省值)。
VBFIRSTFOURDAYS 2 从第一个其大半个星期在新的一年的一周开始。
VBFIRSTFULLWEEK 3 从第一个无跨年度的星期开始。
说明
DATEDIFF 函数可用来决定两个日期之间所指定的时间间隔数目。例如,可以使用 DATEDIFF 来计算两个日期之间相隔几日,或计算从今天起到年底还有多少个星期。
为了计算 DATE1 与 DATE2 相差的日数,可以使用“一年的日数”(Y) 或“日”(D)。当 INTERVAL 是“一周的日数”(W) 时,DATEDIFF 返回两日期间的周数。如果 DATE1 是星期一,DATEDIFF 计算到 DATE2 为止的星期一的个数。这个数包含 DATE2 但不包含 DATE1。不过,如果 INTERVAL 是“周”(WW),则 DATEDIFF 函数返回两日期间的“日历周”数。由计算 DATE1 与 DATE2
之间星期日的个数而得。如果 DATE2 刚好是星期日,则 DATE2 也会被加进 DATEDIFF 的计数结果中;但不论 DATE1 是否为星期日,都不将它算进去。
如果 DATE1 比 DATE2 来得晚,则 DATEDIFF 函数的返回值为负数。
FIRSTDAYOFWEEK 参数会影响使用时间间隔符号 “W” 或 “WW” 计算的结果。
如果 DATE1 或 DATE2 是日期文字,则指定的年份成为该日期的固定部分。但是,如果 DATE1 或 DATE2 用双引号 (" ") 括起来,且年份略而不提,则在每次计算表达式 DATE1 或 DATE2 时,当前年份都会插入到代码之中。这样就可以书写适用于不同年份的程序代码。
在计算 12 月 31 日和来年的 1 月 1 日的年份差时,DATEDIFF 返回 1 表示相差一个年份,虽然实际上只相差一天而已。
java datediff_JAVA中的时间操作(附DATEDIFF函数用法)相关推荐
- Java 8 中 Map 骚操作之 merge() 的用法
点击上方蓝色"程序猿DD",选择"设为星标" 回复"资源"获取独家整理的学习资料! 来源 | juejin.im/post/5d9b455a ...
- mysql对时间操作系统_MySQL时间操作的系统函数用法
oracle length and lengthb LENGTH──返回以字符为单位的字符串长度. LENGTHB──返回以字节为单位的字符串长度,它和类型定义中的长度是一个概念,比如你定义的varc ...
- java时间设置_JAVA中的时间操作
java中的时间操作不外乎这四种情况: 1.获取当前时间 2.获取某个时间的某种格式 3.设置时间 4.时间的运算 好,下面就针对这四种情况,一个一个搞定. 一.获取当前时间 有两种方式可以获得,第一 ...
- mysql中datediff函数用法
mysql中datediff函数用法 1. datediff函数语法用法: 表达式DateDiff(timeinterval,date1,date2 [, firstdayofweek [, firs ...
- linux时间与日期函数,Shell中关于时间和日期的函数总结
shell下获取系统时间的方法直接调用系统变量 获取今天时期:`date +%Y%m%d` 或 `date +%F` 或 $(date +%y%m%d) 获取昨天时期:`date -d yesterd ...
- python字典在编程中的作用_python中的字典操作及字典函数
字典 dict_fruit = {'apple':'苹果','banana':'香蕉','cherry':'樱桃','avocado':'牛油果','watermelon':'西瓜'} 字典的操作 # ...
- python 字典处理_python numpy求解积分python中的字典操作及字典函数
字典 dict_fruit = {'apple':'苹果','banana':'香蕉','cherry':'樱桃','avocado':'牛油果','watermelon':'西瓜'} 字典的操作 W ...
- 一个Java程序中是否只能有一个main函数
否 1.一个Java程序中不一定只有一个main函数,但至少有一个main函数因为Java虚拟机运行时,是以main方法为入口进入的 2.main函数是程序的入口,总之一个Java程序执行时只会执行一 ...
- Java类中this关键字和static关键字的用法详解
今天给大家总结介绍一下Java类中this关键字和static关键字的用法. 文章目录 this关键字用法: 1:修饰属性,表示调用类中的成员变量 2:this修饰方法 3:this表示当前对象的引用 ...
最新文章
- MySQL数据库中外键SQL语句的编写
- 神经网络优化算法综述
- 商务网站开发这些优势值得青睐
- 海量数据处理之Bloom Filter详解
- Python 中使用help()命令后如何退出
- 转载:tcpdump抓包和Wireshark解包
- 精讲23种设计模式-基于装饰模式~设计多级缓存框架
- 面试官:请讲一下Redis主从复制的功能及实现原理
- android studio上拉加载,AndroidStudio的PullToRefreshListView简单使用
- HTML5网页录音和上传到服务器,支持PC、Android,支持IOS微信
- Softreference | WeakReference
- 从纯技术到技术管理,那些跌宕起伏的转型经历
- 计算机二级C常考题型归纳
- 卷积神经网络参数说明
- MATLAB的官方网站上其实有很多MATLAB的学习和使用资料(文档、视频都有不少)
- 全球十大黑客(第一让你不敢想象)
- 华为交换机和路由器命令和trunk
- Python下载库pip pygame
- 力扣刷题 DAY_87 贪心
- CISP——密码学的应用
热门文章
- MIT的学习资料(reading部分)锁与同步学习笔记
- php中smarty末班引擎,php之smarty模板引擎
- 擎创技术流 | java多类加载器类冲突案例分析
- SpringBoot之首页与图标定制
- Vue的基础知识之插值操作
- Soul赴美递交上市申请背后:自造定位、自我打脸,借“约会”营销
- 小试牛刀 --- Tinker集成教程
- 因与公司存在分歧,寒武纪 CTO 梁军离职了
- 支持动态属性的标签库 [ 04-12-30 | 刘冬 ]
- 艾钧教授《“双碳”战略及制造行业发展趋势与机遇》