时间设置

经常看见jsp版里有人问时间操作的问题,这些问题一般包括:取当前时间,把一个指定的字符串时间转化成时间类型,求两个时间之间的天数,求一段时间以前的时间,求一段时间以后的时间,在这里就把这些问题汇总一下。

<%@ page contentType="text/html;charset=gb2312"%>

<%@ page import="java.text.*"%>

<%@ page import="java.util.*"%>

<%

//字符串转化成时间类型(字符串可以是任意类型,只要和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("<br>");

SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

String mDateTime1=formatter.format(d);

out.println(mDateTime1);

out.println("<br>");

out.println(d.getTime());

out.println("<br>");

//当前时间

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("<br>");

//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("<br>");

//明天日期

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("<br>");

//两个时间之间的天数

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("<br>");

 

//加半小时

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("<br>");

 

 

//年月周求日期

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("<br>");

//求是星期几

mydate= myFormatter.parse("2001-1-1");

SimpleDateFormat formatter4 = new SimpleDateFormat("E");

String mydate3=formatter4.format(mydate);

out.println(mydate3);

out.println("<br>");

%>

 

附: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 表示相差一个年份,虽然实际上只相差一天而已。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值