我正在从数据库中检索两个日期时间值。一旦检索到值,我需要两个值之间的差值。 为此,我创建了一个时间跨度变量来存储两个日期值的差值。

TimeSpan? variable = datevalue1 - datevalue2;

现在我需要显示在Timespan变量中存储的小时数的差异。 我提到了TimeSpan。TotalHours,但由于某种原因不能应用相同的。 我怎么做呢? 我在MVC项目上使用c#。我需要简单地显示小时的差异值?

编辑: 由于时间跨度是空的,我不能使用总小时属性。现在我可以通过timeespanval。value。totalhours来使用它;


当前回答

一个更精确的方式为员工支付工时或其他精度要求::

decimal DeterminePreciseHours(DateTime startTimestamp, DateTime stopTimestamp)
{
    var span = (stopTimestamp - startTimestamp).Value;
    decimal total = (decimal)span.TotalMilliseconds / 60 / 60 / 1000;
    return Math.Round(total, PRECISION_CONSTANT);
}

https://dotnetfiddle.net/tVIoVJ

其他回答

这是另一个在c#中减去两个日期的例子…

if ( DateTime.Now.Subtract(Convert.ToDateTime(objDateValueFromDatabase.CreatedOn)).TotalHours > 24 ) 
{ 
... 
} 

哇,我得说:保持简单:

MessageBox.Show("Result: " + (DateTime.Now.AddDays(10) > DateTime.Now));

Result: True

and:

MessageBox.Show("Result: " + DateTime.Now.AddDays(10).Subtract(DateTime.Now));

Result: 10.00:00:00

DateTime对象具有处理布尔结果的所有内置逻辑。

你可能还想看看

var hours = (datevalue1 - datevalue2).TotalHours;

我想你很困惑,因为你没有声明TimeSpan你声明了TimeSpan?这是一个可空的TimeSpan。如果您不需要它为空,可以删除问号,或者使用variable.Value.TotalHours。

使用Nullable有什么原因吗?

如果你想使用Nullable,那么你可以写variable.Value.TotalHours。

或者你可以写:(datevalue1 - datevalue2). totalhours。