2012-10-30 97 views
1

在我的數據庫中,我有一個類型爲varchar(8)的日期字段,我用它來存儲格式爲YYYYMMDD的日期值。我有困難創建一個簡單的CR式顯示在以下格式的時間範圍:水晶報表中優雅的字符串日期(範圍)轉換

2012年10月1日到2012年10月31日

這是我的當前和非常缺乏吸引力CR式:

stringvar yYear; 
stringvar mMonth; 
datevar OrigDate; 
numbervar StartDay; 
stringvar EndDay; 

yYear := Mid ({Command.Date}, 1, 4); 

select Mid ({Command.Date}, 5, 2) 
case "01": mMonth:= "January" 
case "02": mMonth:= "Februry" 
case "03": mMonth:= "March" 
case "04": mMonth:= "April" 
case "05": mMonth:= "May" 
case "06": mMonth:= "June" 
case "07": mMonth:= "July" 
case "08": mMonth:= "August" 
case "09": mMonth:= "September" 
case "10": mMonth:= "October" 
case "11": mMonth:= "November" 
case "12": mMonth:= "December"; 

OrigDate := CDate(ToNumber({Command.Date}[1 to 4]), ToNumber({Command.Date}[5 to 6]), ToNumber({Command.Date}[7 to 8])); 
StartDay := ToNumber({Command.Date}[7 to 8]); 
EndDay := Mid(ToText(DateSerial(Year(OrigDate), Month(OrigDate) +1, 1-1)), 4, 2); 

mMonth + " " + ToText(StartDay, "#") + ", " + yYear + " to " + mMonth + " " + EndDay + ", " + yYear 

這樣做很有效,但本着可維護性和良好/乾淨編碼實踐的精神,如果可能的話,我想簡化這個功能。

我相對較新的水晶書面報告,所以我希望我沒有「重新發明輪子」。

回答

0

試試這個:

local numbervar year := tonumber(left({Command.Date},4)); 
local numbervar month:= tonumber(mid({Command.Date},5,2)); 
local numbervar day := tonumber(right({Command.Date},2)); 
local datevar stDate := date(year,month,day); 
local datevar endDate := dateserial(year,month+1,day-1); //get last day of month 

totext(stDate,"MMMM d, yyyy") + " to " + totext(endDate,"MMMM d, yyyy") 
+0

謝謝瑞恩。我知道必須有一個更簡單的解決方案。過度思考的危險...... – 8thWonder

0

烘乾機的解決方案?

創建一個自定義函數:

// YYYYMMDD() 
// Convert a value in 'YYYYMMDD' to a Date 
Function (Stringvar value) 

    Date(ToNumber(value[1 to 4]), ToNumber(value[5 to 6]), ToNumber(value[7 to 8])) 

創建的起始日期的公式:

//{@Starting Date} 
YYYYMMDD({Command.Date}) 

創建的結束日期的公式:

//{@Ending Date} 
// find first day of current month, add a month, subtract a day, truncate time 
Date(DateAdd("m", 1, Date(Year({@Starting Date}), Month({@Starting Date}), 1)) - 1) 

嵌入這兩個公式域在文本字段中並根據需要格式化每個字段(增加靈活性)。