1. 查詢兩個日期相差的月數和剩下的天數
對於任意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);
}
}
2. sql 中,如何獲取兩個日期之前月數,周數,天數
定義和用法
DATEDIFF() 函數返回兩個日期之間的時間。
語法
DATEDIFF(datepart,startdate,enddate)
datepart 縮寫
年 yy, yyyy
季度 qq, q
月 mm, m
年中的日 dy, y
日 dd, d
周 wk, ww
星期 dw, w
小時 hh
分鍾 mi, n
秒 ss, s
毫秒 ms
微妙 mcs
納秒 ns
--相差月數
SELECTDATEDIFF(mm,'2018-1-30','2018-12-31')
--相差周數
SELECTDATEDIFF(wk,'2018-1-30','2018-12-31')
--相差天數
SELECTDATEDIFF(dd,'2018-1-30','2018-12-31')
3. 求用sql求兩個日期相隔的月數,比如2013-1-1和2014-2-1,相隔為14個月,精確到月
select datediff(month, 開始日期,結束日期);
4. sql查詢問題 我想查詢兩個日期之間的數據,比如3月到4月的數據,這個sql語句該怎麼寫
最簡單的方法就是用char(4)來保存生日。
select student_name
from students
where student_birthday between '0101' and '0505'
order by student_birthday
也可以用數值型:)
select student_name
from students
where student_birthday between 101 and 505
order by student_birthday
當然也可以用日期型
5. Oracle怎麼樣用sql語句得出相差的月數
使用Months_between(f,s) 日期f和s間相差月數,但結果有小數。你要整數,可以進行截取。
實例:
SELECT Months_between(SYSDATE,input_date) FROM aa_yudy_deal
6. 如何寫SQL語句,判斷是否間隔超過一個月
datediff函數
邏輯是月份+1,並且日期大於之前的日期,就可以判斷超過一個月了
declare@datetime1datetime,@datetime2datetime
set@datetime1='2017-5-25'
set@datetime2=getdate()
--(1)結果等於1
selectdatediff(month,@datetime1,@datetime2)
--(2)結果大於0
selectday(@datetime2)-day(@datetime1)
--(1)和(2)的條件同時滿足就超過一個月了。ps如果要判斷超過兩月及以上滿足第(1)個條件大於1就行了
7. PL/SQL中如何求兩個日期之間相差的年月日(就是要得到這樣的數據:YYYYMMDD),要精確值
用months_between()
函數求出兩個日期相差的月數,這個求出來比較准確,可以滿足精確計算工齡也比較符合業務需求,再除以12
select
months_between(sysdate,date'2012-01-01')
from
al;
8. sqlserver中返回兩個日期間相差幾年零幾月
select datediff(month,'2017-1-5','2018-05-25')/12 ,datediff(month,'2017-1-5','2018-05-25')%12
執行結果:1年4個月
注釋:
datediff(month,'2017-1-5','2018-05-25')取出兩個日期相差的總月數;
datediff(month,'2017-1-5','2018-05-25')/12 取出兩個日期相差的總年數。
datediff(month,'2017-1-5','2018-05-25')%12 取出總年數後,剩餘月數。
9. sql數值型日期怎麼相減得到月份差
select datediff(year, 開始日期,結束日期); --兩日期間隔年
select datediff(quarter, 開始日期,結束日期); --兩日期間隔季
select datediff(month, 開始日期,結束日期); --兩日期間隔月
select datediff(day, 開始日期,結束日期); --兩日期間隔天
select datediff(week, 開始日期,結束日期); --兩日期間隔周
select datediff(hour, 開始日期,結束日期); --兩日期間隔小時
select datediff(minute, 開始日期,結束日期); --兩日期間隔分
select datediff(second, 開始日期,結束日期); --兩日期間隔秒