一些時間日期函式,轉自華軟
可以直接賦值給變數,不用寫成函式形式的。另函式適用於pb6.5,一個漢字佔兩個位元組,如果用於pb8.0以上請根據實際情況修改
//1.生肖(年份引數:int ls_year 返回引數:string):
mid(fill('鼠牛虎兔龍蛇馬羊猴雞狗豬',48),(mod(ls_year -1900,12)+13)*2 -1,2)
//2.天干地支(年份引數:int ls_year 返回引數:string):
mid(fill('甲乙丙丁戊己庚辛壬癸',40),(mod(ls_year -1924,10)+11)*2 -1,2)+mid(fill('子醜寅卯辰巳午未申酉戌亥',48),(mod(ls_year -1924,12)+13)*2 -1,2)
//3.星座(日期引數:date ls_date 返回引數:string):
mid("摩羯水瓶雙魚白羊金牛雙子巨蟹獅子處女天秤天蠍射手摩羯",(month(ls_date)+sign(sign(day(ls_date) -(19+integer(mid('102123444423',month(ls_date),1))))+1))*4 -3,4)+'座'
//4.判斷閏年(年份引數:int ls_year 返回引數:int 0=平年,1=閏年):
abs(sign(mod(sign(mod(abs(ls_year),4))+sign(mod(abs(ls_year),100))+sign(mod(abs(ls_year),400)),2)) -1)
//5.某月天數(日期引數:date ls_date 返回引數:int):
integer(28+integer(mid('3'+string(abs(sign(mod(sign(mod(abs(year(ls_date)),4))+sign(mod(abs(year(ls_date)),100))+sign(mod(abs(year(ls_date)),400)),2)) -1))+'3232332323',month(ls_date),1)))
//6.某月最後一天日期(日期引數:date ls_date 返回引數:date): date(year(ls_date),month(ls_date),
integer(28+integer(mid('3'+string(abs(sign(mod(sign(mod(abs(year(ls_date)),4))+sign(mod(abs(year(ls_date)),100))+sign(mod(abs(year(ls_date)),400)),2)) -1))+'3232332323',month(ls_date),1))))
//7.另一個求某月最後一天日期(日期引數:date ls_date 返回引數:date):
a. RelativeDate (date(year(ls_date)+sign(month(ls_date) -12)+1,mod(month(ls_date)+1,13)+abs(sign(mod(month(ls_date)+1,13)) -1),1),-1) b. RelativeDate(date(year(ls_date)+integer(month(ls_date)/12),mod(month(ls_date),12)+1,1),-1)
//8.另一個求某月天數(日期引數:date ls_date 返回引數:int):
a. day(RelativeDate (date(year(ls_date)+sign(month(ls_date) -12)+1,mod(month(ls_date)+1,13)+abs(sign(mod(month(ls_date)+1,13)) -1),1),-1))
b. day(RelativeDate(date(year(ls_date)+integer(month(ls_date)/12),mod(month(ls_date),12)+1,1),-1))
//9.某月某日星期幾--同PB系統函式DayName(日期引數:date ls_date 返回引數:string):
'星期'+mid('日一二三四五六',(mod(year(ls_date) -1 + int((year(ls_date) -1)/4) - int((year(ls_date) -1)/100) + int((year(ls_date) -1)/400) + daysafter(date(year(ls_date),1,1),ls_date)+1,7)+1)*2 -1,2)
//10.求相隔若干月份後的相對日期(日期引數:date ls_date 相隔月份(可取負數):int ls_add_month 返回引數:date):
date(year(ls_date)+int((month(ls_date)+ls_add_month)/13),long(mid(fill('010203040506070809101112',48),(mod(month(ls_date)+ls_add_month -1,12)+13)*2 -1,2)),day(ls_date) -integer(right(left(string(day(RelativeDate (date(year(ls_date)+int((month(ls_date)+ls_add_month)/13)+sign(long(mid(fill('010203040506070809101112',48),(mod(month(ls_date)+ls_add_month -1,12)+13)*2 -1,2)) -12)+1,mod(long(mid(fill('010203040506070809101112',48),(mod(month(ls_date)+ls_add_month -1,12)+13)*2 -1,2))+1,13)+abs(sign(mod(long(mid(fill('010203040506070809101112',48),(mod(month(ls_date)+ls_add_month -1,12)+13)*2 -1,2))+1,13)) -1),1),-1)) -day(ls_date),'00')+'00000',5),3))/100)
//11.求某日在當年所處的週數(日期引數:date ls_date 返回引數:int): //a.周始日為星期天
//a1 abs(int(-((daysafter( RelativeDate(date(year(ls_date),1,1), -mod(year(ls_date) -1 + int((year(ls_date) -1)/4) - int((year(ls_date) -1)/100) + int((year(ls_date) -1)/400) + 1,7) +1),ls_date)+1)/7))) //a2(使用DayNumber函式) abs(int(-((daysafter( RelativeDate(date(year(ls_date),1,1), -DayNumber(date(year(ls_date),1,1))+1),ls_date)+1)/7))) //b.周始日為星期一 //b1 abs(int(-((daysafter( RelativeDate(date(year(ls_date),1,1), -integer(mid('6012345',mod(year(ls_date) -1 + int((year(ls_date) -1)/4) - int((year(ls_date) -1)/100) + int((year(ls_date) -1)/400) + 1,7),1))),ls_date)+1)/7)))
//b2(使用DayNumber函式) abs(int(-((daysafter( RelativeDate(date(year(ls_date),1,1), -integer(mid('6012345',DayNumber(date(year(ls_date),1,1)),1))),ls_date)+1)/7)))
//12.求某日相對於過去某一日期所處的週數(日期引數:date ls_date_1(要求的某日),ls_date_2(過去的某日) 返回引數:int): //注:ls_date_1>ls_date_2
//a.周始日為星期天 //a1 abs(int(-((daysafter( RelativeDate(ls_date_2, -mod(year(ls_date_2) -1 + int((year(ls_date_2) -1)/4) - int((year(ls_date_2) -1)/100) + int((year(ls_date_2) -1)/400) + daysafter(date(year(ls_date_2),1,1),ls_date_2)+ 1,7) +1),ls_date_1)+1)/7)))
//a2(使用DayNumber函式) abs(int(-((daysafter( RelativeDate(ls_date_2, -DayNumber(ls_date_2)+1),ls_date_1)+1)/7)))
//b.周始日為星期一 //b1 abs(int(-((daysafter( RelativeDate(ls_date_2, -integer(mid('6012345',mod(year(ls_date_2) -1 + int((year(ls_date_2) -1)/4) - int((year(ls_date_2) -1)/100) + int((year(ls_date_2) -1)/400) + daysafter(date(year(ls_date_2),1,1),ls_date_2)+ 1,7) ,1))),ls_date_1)+1)/7)))
//b2(使用DayNumber函式) abs(int(-((daysafter( RelativeDate(ls_date_2, -integer(mid('6012345',DayNumber(ls_date_2),1))),ls_date_1)+1)/7)))
13 PB中 DaysAfter ( date1, date2 ) 只能返回日期型別相差天數,SecondsAfter ( time1, time2 )只能返回時間相差妙,沒有真對日期時間型別的函式,可以用下面一條語句實現:
lont ll_allseconds
datetime ldt_bgn,ldt_end
ll_allseconds=(daysafter(date(ldt_bgn),date(ldt_end))*86400+SecondsAfter(time(ldt_bgn),time(ldt_end)))
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/3090/viewspace-594474/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 日期時間函式函式
- Clickhouse 時間日期函式函式
- SPL 的日期時間函式函式
- MySQL日期時間函式大全MySql函式
- MySQL 日期時間函式大全MySql函式
- ORACLE日期時間函式大全Oracle函式
- SQLServer時間日期函式速查SQLServer函式
- MySQL 的日期和時間函式MySql函式
- SQL SERVER 時間和日期函式SQLServer函式
- ORACLE中日期和時間函式彙總(轉載)Oracle函式
- SQL 10 函式 3 日期時間函式 - 5 計算日期差額SQL函式
- MySQL日期和時間函式彙總MySql函式
- Go基礎-時間和日期函式Go函式
- Sql Server系列:日期和時間函式SQLServer函式
- mysql日期和時間函式學習MySql函式
- WPS表格日期與時間函式函式
- Sql Server函式全解(4):日期和時間函式SQLServer函式
- Sql Server函式全解(四)日期和時間函式SQLServer函式
- mysql 時間相關的函式 以及日期和字串互轉MySql函式字串
- 使用mysql日期與時間函式輕易搞定日期與時間邏輯MySql函式
- SQL Server 裡的日期和時間函式SQLServer函式
- javascript時間物件Date常用時間日期函式簡單分享JavaScript物件函式
- MySQL中日期和時間戳互相轉換的函式和方法MySql時間戳函式
- js Date()建構函式建立時間日期物件JS函式物件
- javascript 日期時間函式(經典+完善+實用)JavaScript函式
- C/C++中的日期和時間函式C++函式
- 探索MySQL高階語句(數學函式、聚合函式、字串函式、日期時間函式)MySql函式字串
- mysql時間和日期轉換的一些例子MySql
- oracle時間間隔轉換函式Oracle函式
- hive時間日期函式及典型場景應用Hive函式
- MySQL 5.7關於日期和時間的函式整理MySql函式
- MySql中時間和日期函式MySql函式
- js將時間日期物件轉換為時間日期字元JS物件字元
- MySQL 日期函式、時間函式在實際場景中的應用MySql函式
- ACCESS支援的時間日期函式2007年01月10日 16:01ACCESS支援的時間日期函式函式
- 轉換時間戳的函式時間戳函式
- js日期轉換函式JS函式
- Oracle的日期函式(轉)Oracle函式