C# DateTime对象的所有使用规则 (转)


dt.AddTicks(1000).ToString();//2005-11-5 13:47:04
dt.CompareTo(dt).ToString();//0
dt.Add(?).ToString();//问号为一个时间段
dt.Equals("2005-11-6 16:11:04").ToString();//False
dt.Equals(dt).ToString();//True
dt.GetHashCode().ToString();//1474088234
dt.GetType().ToString();//System.DateTime
dt.GetTypeCode().ToString();//DateTime
   
dt.GetDateTimeFormats(''s'')[0].ToString();//2005-11-05T14:06:25
dt.GetDateTimeFormats(''t'')[0].ToString();//14:06
dt.GetDateTimeFormats(''y'')[0].ToString();//2005年11月
dt.GetDateTimeFormats(''D'')[0].ToString();//2005年11月5日
dt.GetDateTimeFormats(''D'')[1].ToString();//2005 11 05
dt.GetDateTimeFormats(''D'')[2].ToString();//星期六 2005 11 05
dt.GetDateTimeFormats(''D'')[3].ToString();//星期六 2005年11月5日
dt.GetDateTimeFormats(''M'')[0].ToString();//11月5日
dt.GetDateTimeFormats(''f'')[0].ToString();//2005年11月5日 14:06
dt.GetDateTimeFormats(''g'')[0].ToString();//2005-11-5 14:06
dt.GetDateTimeFormats(''r'')[0].ToString();//Sat, 05 Nov 2005 14:06:25 GMT

string.Format("{0:d}",dt);//2005-11-5
string.Format("{0:D}",dt);//2005年11月5日
string.Format("{0:f}",dt);//2005年11月5日 14:23
string.Format("{0:F}",dt);//2005年11月5日 14:23:23
string.Format("{0:g}",dt);//2005-11-5 14:23
string.Format("{0:G}",dt);//2005-11-5 14:23:23
string.Format("{0:M}",dt);//11月5日
string.Format("{0:R}",dt);//Sat, 05 Nov 2005 14:23:23 GMT
string.Format("{0:s}",dt);//2005-11-05T14:23:23
string.Format("{0:t}",dt);//14:23
string.Format("{0:T}",dt);//14:23:23
string.Format("{0:u}",dt);//2005-11-05 14:23:23Z
string.Format("{0:U}",dt);//2005年11月5日 6:23:23
string.Format("{0:Y}",dt);//2005年11月
string.Format("{0}",dt);//2005-11-5 14:23:23 
string.Format("{0:yyyyMMddHHmmssffff}",dt);


计算2个日期之间的天数差
-----------------------------------------------
DateTime dt1 = Convert.DateTime("2007-8-1");    
DateTime dt2 = Convert.DateTime("2007-8-15");   
TimeSpan span = dt2.Subtract(dt1);              
int dayDiff = span.Days + 1;                   

计算某年某月的天数
-----------------------------------------------    
int days = DateTime.DaysInMonth(2007, 8);       
days = 31;                                     

给日期增加一天、减少一天
-----------------------------------------------
DateTime dt =DateTime.Now;
dt.AddDays(1); //增加一天
dt.AddDays(-1);//减少一天
其它年份方法类似...

Oracle SQL里转换日期函数
-----------------------------------------------
to_date("2007-6-6",''YYYY-MM-DD");
to_date("2007/6/6",''yyyy/mm/dd");


如下一组数据,如何查找表里包含9月份的记录:
CGGC_STRATDATE  CGGC_ENDDATE
=========================================
2007-8-4  2007-9-5
2007-9-5  2007-9-20
2007-9-22  2007-10-5

SELECT * FROM TABLE
(TO_DATE(''2007/9/1'',''yyyy/mm/dd'') BETWEEN CGGC_STRATDATE
AND CGGC_ENDDATE OR CGGC_STRATDATE >=TO_DATE(''2007/9/1'',''yyyy/mm/dd'')
AND CGGC_ENDDATE<=TO_DATE(''2007/9/30'',''yyyy/mm/dd'') "
OR TO_DATE(''2007/9/30'',''yyyy/mm/dd'') BETWEEN CGGC_STRATDATE
AND CGGC_ENDDATE) ORDER BY CGGC_STRATDATE ASC

原文地址:https://www.cnblogs.com/y5042/p/2149912.html