查询两个日期相差的月数和剩下的天数

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了查询两个日期相差的月数和剩下的天数相关的知识,希望对你有一定的参考价值。

通过SQL计算两个时间的月数,剩下的天数除以当月的天数,如果超过一半或等于一半则为1,如果小于一半,则为0.5天,例如2006年2月1日到2006年7月13日,整月为5个月,还有13除以7月的31天,不过半,则为0.5,数据显示为8.5.
最好能用视图做.
以上题法有些错误.
要按以下要求进行.根据两个时间相减,每月赋值1,如果有一个月的天数超过一半或等于一半则为1,如果小于一半则为0.5,例如,2006年2月1日到2006年7月31日,数据显示如下.
year months amount
2006年 2 1
2006年 3 1
2006年 4 1
2006年 5 1
2006年 6 1
2006年 7 0.5
前面所说的答案本人计算错误了,请高人指点,最好能用视通过两个时间后得到显示的数据. 两个时间是变动的.

对于任意2个日期比如:date_start=2006-10-1、date_end=2006-10-14 ,首先计算这连个日期之间的时间间隔(天数),然后分别对date_start 和date_end 取得它们下一个星期一的日期,这样就可以得到一个新的可以整除7的完整日期间隔(这个新的日期间隔已经把星期几的问题剔出掉了),换一种说法就是我们可以得到,这两个新的日期之间的周数,拿这个周数乘以5就是工作日期了(tmpWorkingDays)。但是这个日期并不是我们所要的日期,接下来我们要做的就是计算date_start,date_end这两个日期对于根据它们所产生的新的日期之间的时间偏移量,date_start的偏移量(date_start_change)是需要加的,而date_end的这个偏移量(date_end_change)是需要减去的。 最后我们只要用tmpWorkingDays+date_start_change-date_end_change就是我们所要求的实际工作日了。以下是所有实现代码(两个日期跨年也没有问题)。

package com.date.utlit;

import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
import java.util.GregorianCalendar;
/**
* 计算任意2个日期内的工作日(没有考虑到国定假日)
* @author user
*
*/
public class DateCal

/**
* @param args
*/
public static void main(String[] args)
try

String strDateStart = "2006-10-1";
String strDateEnd = "2006-10-14";
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
Date date_start = sdf.parse(strDateStart);
Date date_end = sdf.parse(strDateEnd);
DateCal app = new DateCal();
Calendar cal_start = Calendar.getInstance();
Calendar cal_end = Calendar.getInstance();
cal_start.setTime(date_start);
cal_end.setTime(date_end);
System.out.println("星期-->" + app.getChineseWeek(cal_start)
+ " 日期-->" + cal_start.get(Calendar.YEAR) + "-"
+ (cal_start.get(Calendar.MONTH) + 1) + "-"
+ cal_start.get(Calendar.DAY_OF_MONTH));
System.out.println("星期-->" + app.getChineseWeek(cal_end) + " 日期-->"
+ cal_end.get(Calendar.YEAR) + "-"
+ (cal_end.get(Calendar.MONTH) + 1) + "-"
+ cal_end.get(Calendar.DAY_OF_MONTH));
System.out.println("工作日为-->"
+ app.getWorkingDay(cal_start, cal_end));
System.out.println("休息日-->"+app.getHolidays(cal_start, cal_end));
catch (Exception e)
// TODO: handle exception



public int getDaysBetween(java.util.Calendar d1, java.util.Calendar d2)
if (d1.after(d2)) // swap dates so that d1 is start and d2 is end
java.util.Calendar swap = d1;
d1 = d2;
d2 = swap;

int days = d2.get(java.util.Calendar.DAY_OF_YEAR)
- d1.get(java.util.Calendar.DAY_OF_YEAR);
int y2 = d2.get(java.util.Calendar.YEAR);
if (d1.get(java.util.Calendar.YEAR) != y2)
d1 = (java.util.Calendar) d1.clone();
do
days += d1.getActualMaximum(java.util.Calendar.DAY_OF_YEAR);
d1.add(java.util.Calendar.YEAR, 1);
while (d1.get(java.util.Calendar.YEAR) != y2);

return days;


/**
* 计算2个日期之间的相隔天数
* @param d1
* @param d2
* @return
*/
public int getWorkingDay(java.util.Calendar d1, java.util.Calendar d2)
int result = -1;
if (d1.after(d2)) // swap dates so that d1 is start and d2 is end
java.util.Calendar swap = d1;
d1 = d2;
d2 = swap;


int betweendays = getDaysBetween(d1, d2);

int charge_date = 0;
int charge_start_date = 0;//开始日期的日期偏移量
int charge_end_date = 0;//结束日期的日期偏移量
// 日期不在同一个日期内
int stmp;
int etmp;
stmp = 7 - d1.get(Calendar.DAY_OF_WEEK);
etmp = 7 - d2.get(Calendar.DAY_OF_WEEK);
if (stmp != 0 && stmp != 6) // 开始日期为星期六和星期日时偏移量为0
charge_start_date = stmp - 1;

if (etmp != 0 && etmp != 6) // 结束日期为星期六和星期日时偏移量为0
charge_end_date = etmp - 1;

//
result = (getDaysBetween(this.getNextMonday(d1), this.getNextMonday(d2)) / 7)
* 5 + charge_start_date - charge_end_date;
//System.out.println("charge_start_date>" + charge_start_date);
//System.out.println("charge_end_date>" + charge_end_date);
//System.out.println("between day is-->" + betweendays);
return result;


public String getChineseWeek(Calendar date)
final String dayNames[] = "星期日", "星期一", "星期二", "星期三", "星期四", "星期五",
"星期六" ;

int dayOfWeek = date.get(Calendar.DAY_OF_WEEK);

// System.out.println(dayNames[dayOfWeek - 1]);
return dayNames[dayOfWeek - 1];



/**
* 获得日期的下一个星期一的日期
*
* @param date
* @return
*/
public Calendar getNextMonday(Calendar date)
Calendar result = null;
result = date;
do
result = (Calendar) result.clone();
result.add(Calendar.DATE, 1);
while (result.get(Calendar.DAY_OF_WEEK) != 2);
return result;


/**
*
* @param d1
* @param d2
* @return
*/
public int getHolidays(Calendar d1,Calendar d2)
return this.getDaysBetween(d1, d2)-this.getWorkingDay(d1, d2);



参考技术A 用存储过程吧。。
create proc proc1
@BD datetime,@ED datetime
as
Begin
declare @DD datetime
if @BD<=@ED
begin
if datediff(mm,@BD,@ED)>0
begin
while @BD<@ED
begin
set @DD=cast(convert(varchar(7),dateadd(mm,1,@BD),120)+'-01' as datetime)-1
if @DD>@ED
set @DD=@ED
if datediff(dd,@BD,@DD)>15
begin
print convert(varchar(7),@BD,120)+' 1'
end
else
begin
print convert(varchar(7),@BD,120)+' 0.5'
end
set @BD=@DD+1
end
end
end
End

测试成功~~
执行: exec proc1 '2008-01-05','2009-03-06'
很简单。。。。把>15那里换个方法就可以了。。
if datediff(dd,@BD,@DD)>15 这个条件更换为:
if datediff(dd,@BD,@DD)>datepart(dd,@DD)/2本回答被提问者采纳
参考技术B 没用视图,你转换下
create table my( years char(4),months int ,amount varchar(3))

declare @x varchar(15),@y varchar(15),@z varchar(15)
declare @f_m int,@e_m int
set @x='2006年2月1日'
set @y='2006年7月13日'
set @x=Replace(replace(REPLACE(@x,'年','-'),'月','-'),'日','')
set @y=Replace(replace(REPLACE(@y,'年','-'),'月','-'),'日','')
set @f_m=MONTH(@x)
set @e_m=MONTH(@y)

declare @i int,@f_d int,@e_d int,@d int
set @f_d=DAY(@x)
set @i=@f_m

while @i<=@e_m
begin
if @i=@e_m
set @z=@y
else
set @z=cast(year(@x)as varchar(4))+'-'+cast(@i+1 as varchar(2))+'-'+'1'
set @d=DATEDIFF(dd,@x,@z)
if @d>=15
insert into my select YEAR(@x) as years,@i as months,'1' as amount
else
insert into my select YEAR(@x) as years,@i as months,'0.5' as amount
set @x=@z
set @i=@i+1
end

select * from my
drop table my
参考技术C 问题表述不清楚,回答的人也是风牛马不相及,
表述清楚点,我可以给你解决.
参考技术D 这个好找 到百度上搜索 廖阅鹏催眠音乐 那网站里面就有

Java计算两个日期时间相差几天,几小时,几分钟等

思路是先计算两个日期相差的毫秒数,然后分别根据每天的毫秒数、每小时的毫秒数、每分钟的毫秒数来计算相差几天,几小时,几分钟。具体代码如下:

public static String getDatePoor(Date endDate, Date nowDate)

long nd = 1000 * 24 * 60 * 60;//每天毫秒数

long nh = 1000 * 60 * 60;//每小时毫秒数

long nm = 1000 * 60;//每分钟毫秒数

long diff = endDate.getTime() - nowDate.getTime(); // 获得两个时间的毫秒时间差异

long day = diff / nd;   // 计算差多少天

long hour = diff % nd / nh; // 计算差多少小时

long min = diff % nd % nh / nm;  // 计算差多少分钟

return day + "天" + hour + "小时" + min + "分钟";

然后做一个测试,调用这个方法测试一下:

可以看出两个日期时间相差几天,几小时,几分钟都可以算出来。

扩展资料:

Java使用以下三种方法来比较两个日期:

1、使用 getTime() 方法获取两个日期(自1970年1月1日经历的毫秒数值),然后比较这两个值。

2、使用方法 before(),after() 和 equals()。例如,一个月的12号比18号早,则 new Date(99, 2, 12).before(new Date (99, 2, 18)) 返回true。

3、使用 compareTo() 方法,它是由 Comparable 接口定义的,Date 类实现了这个接口。

参考资料:

Oracle官方API接口-Util-Date

Oracle官方API接口-SimpleDateFormat

菜鸟教程-Java 日期时间


参考技术A Java计算两个日期时间相差几天,几小时,几分钟,其实好简单就可以实现jsp,java中计算两个时间差了public class Test public void dateDiff(String startTime, String endTime, String format) //按照传入的格式生成一个simpledateformate对象SimpleDateFormat sd = new SimpleDateFormat(format);long nd = 1000*24*60*60;//一天的毫秒数long nh = 1000*60*60;//一小时的毫秒数long nm = 1000*60;//一分钟的毫秒数long ns = 1000;//一秒钟的毫秒数long diff;try //获得两个时间的毫秒时间差异diff = sd.parse(endTime).getTime() - sd.parse(startTime).getTime();long day = diff/nd;//计算差多少天long hour = diff%nd/nh;//计算差多少小时long min = diff%nd%nh/nm;//计算差多少分钟long sec = diff%nd%nh%nm/ns;//计算差多少秒//输出结果System.out.println("时间相差:"+day+"天"+hour+"小时"+min+"分钟"+sec+"秒。");本回答被提问者采纳 参考技术B 请用getTime()获得秒数
Date a,b;
a = new Date();
b = new Date();
b.getTime() - a.getTime();

以上是关于查询两个日期相差的月数和剩下的天数的主要内容,如果未能解决你的问题,请参考以下文章

如何用PHP+MySQL计算两个日期之间的月份数和其余下的天数?

SQL是计算两个日期相差多少天数的函数?

C语言求两个日期相差的天数

vfp中要计算两个日期间相差天数如何编写程序?

如何用EXCEL计算两个日期之间相差的年数和月数?

如何用excel计算两个日期之间相差的年数和月数