查询两个日期相差的月数和剩下的天数
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
前面所说的答案本人计算错误了,请高人指点,最好能用视通过两个时间后得到显示的数据. 两个时间是变动的.
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 日期时间
Date a,b;
a = new Date();
b = new Date();
b.getTime() - a.getTime();
以上是关于查询两个日期相差的月数和剩下的天数的主要内容,如果未能解决你的问题,请参考以下文章