数据库中的时间起点1970,1,1,C#中时间起点0001,1,1,之间的转换
int time = 1234567891;(数据库中的存储的秒数)
DateTime BaseDateTime = new DateTime(1970, 1, 1);
DateTime ValidityDateTime = BaseDateTime.AddSeconds(timeSpan);
DateTime NowDateTime = DateTime.Now;
TimeSpan subtractSpan = NowDateTime - ValidityDateTime;
?
?
.DateTime dt1 = DateTime.Now; 2 DateTime dt2 = DateTime.Now.AddDays(-7); 3 TimeSpan ts = dt1 - dt2; 4 5 int days = ts.Days; //dt1和dt2相差多少天 6 7 eg2. 8 //编辑月份和系统登录月份是否相等 9 if(Convert.ToDateTime(DateTime.Now.ToShortDateString()).Month==Convert.ToDateTime(this.GetQueryString("sdate")).Month)10 {11 TimeSpan ts=Convert.ToDateTime(DateTime.Now.ToShortDateString())-Convert.ToDateTime(this.GetQueryString("sdate"));12 iDays=ts.Days;13 //登录系统的前三天可以编辑14 if(iDays<4)15 {16 Submiter submit =new Submiter(this,"tt");17 this.iseretail.SelectedValue=this.GetQueryString("rid");18 this.txtTime.Text=this.GetQueryString("sdate").ToString();19 this.InputSelect1.WhereCondition=" gxlshd='"+this.GetQueryString("rid")+"'";20 if(this.GetQueryString("workid")!="")21 this.InputSelect1.SelectedValue=this.GetQueryString("workid");22 submit.InitInsertMode();23 SetDataGrid();24 }25 eg3.C#中计算两个时间的差26 27 ///<summary>28 /// 计算两个日期的时间间隔29 ///</summary>30 ///<param name="DateTime1">第一个日期和时间</param>31 ///<param name="DateTime2">第二个日期和时间</param>32 ///<returns></returns>33 privatestring DateDiff(DateTime DateTime1, DateTime DateTime2)34 {35 string dateDiff =null;36 37 TimeSpan ts1 =new TimeSpan(DateTime1.Ticks);38 TimeSpan ts2 =new TimeSpan(DateTime2.Ticks);39 TimeSpan ts = ts1.Subtract(ts2).Duration();40 dateDiff = ts.Days.ToString()+"天"41 + ts.Hours.ToString()+"小时"42 + ts.Minutes.ToString()+"分钟"43 + ts.Seconds.ToString()+"秒";44 45 return dateDiff;46 }说明:1.DateTime值类型代表了一个从公元0001年1月1日0点0分0秒到公元9999年12月31日23点59分59秒之间的具体日期时刻。因此,你可以用DateTime值类型来描述任何在想象范围之内的时间。一个DateTime值代表了一个具体的时刻
2.TimeSpan值包含了许多属性与方法,用于访问或处理一个TimeSpan值
下面的列表涵盖了其中的一部分:
Add:与另一个TimeSpan值相加。?
Days:返回用天数计算的TimeSpan值。?
Duration:获取TimeSpan的绝对值。?
Hours:返回用小时计算的TimeSpan值?
Milliseconds:返回用毫秒计算的TimeSpan值。?
Minutes:返回用分钟计算的TimeSpan值。?
Negate:返回当前实例的相反数。?
Seconds:返回用秒计算的TimeSpan值。?
Subtract:从中减去另一个TimeSpan值。?
Ticks:返回TimeSpan值的tick数。?
TotalDays:返回TimeSpan值表示的天数。?
TotalHours:返回TimeSpan值表示的小时数。?
TotalMilliseconds:返回TimeSpan值表示的毫秒数。?
TotalMinutes:返回TimeSpan值表示的分钟数。?
TotalSeconds:返回TimeSpan值表示的秒数。