Ts 计算时间差

/**
 * 时间差计算
 * @param Time1 对比时间
 * @param Time2 时间 默认现在时刻
 * @returns 对象
 * all:[ 是否未来时间 , 年, 日, 时, 分, 秒] 
 */
const TimeDiff = (Time1: Date | string | number, Time2: Date | null | string | number = null) => {
  let D1: Date = new Date(Time1)
  let D2: Date = Time2 ? new Date(Time2) : new Date()
  let DiffT = Number(D2) - Number(D1)
  let Diff: any= {
    ms: DiffT,
    s: Math.trunc((DiffT) / 1000),
    m: Math.trunc((DiffT) / 60000),
    h: Math.trunc((DiffT) / 3600000),
    d: Math.trunc((DiffT) / 86400000),
    y: Math.trunc((DiffT) / 31536000000),
    all:[0, 0, 0, 0, 0, 0]
  }
  DiffT = DiffT / 1000
  if (DiffT < 0) {
    DiffT *= -1
    Diff.all[0] = 1
  }
  Diff.all[1] = Math.trunc(DiffT / 31536000)
  if (Diff.all[1]) DiffT -= Diff.all[1] * 31536000
  Diff.all[2] = Math.trunc(DiffT / 86400)
  if (Diff.all[2]) DiffT -= Diff.all[2] * 86400
  Diff.all[3] = Math.trunc(DiffT / 3600)
  if (Diff.all[3]) DiffT -= Diff.all[3] * 3600
  Diff.all[4] = Math.trunc(DiffT / 60)
  if (Diff.all[4]) DiffT -= Diff.all[4] * 60
  Diff.all[5] = Math.trunc(DiffT)
  return Diff
}
console.table(
  TimeDiff(
    '1987-5-8 8:8:8 '
  )
);

let AAAA = TimeDiff('2023-1-8 8:8:8 ', '2029-2-9 9:9:9 ')
console.log('2023-1-8 8:8:8 ', '2029-2-9 9:9:9 ', AAAA.all[1] + '年' + AAAA.all[2] + '天' + AAAA.all[3] + '小时' + AAAA.all[4] + '分钟' + AAAA.all[5] + '秒 ' + (AAAA.all[0] ? ' 前' : ' 后'));
AAAA = TimeDiff('2023-1-8 8:8:8 ', '2021-2-9 9:9:9 ')
console.log('2023-1-8 8:8:8 ', '2021-2-9 9:9:9 ', +AAAA.all[1] + '年' + AAAA.all[2] + '天' + AAAA.all[3] + '小时' + AAAA.all[4] + '分钟' + AAAA.all[5] + '秒 ' + (AAAA.all[0] ? ' 前' : ' 后'));


打印结果

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 在Oracle中,计算两个timestamp之间的时间差可以通过以下方法实现: 1. 使用时间差函数:可以使用“extract”函数获取两个时间戳之间的差值,例如: ``` SELECT EXTRACT(DAY FROM (timestamp2 - timestamp1)) AS day_diff, EXTRACT(HOUR FROM (timestamp2 - timestamp1)) AS hour_diff, EXTRACT(MINUTE FROM (timestamp2 - timestamp1)) AS minute_diff, EXTRACT(SECOND FROM (timestamp2 - timestamp1)) AS second_diff FROM my_table; ``` 这将返回两个时间戳之间的天数、小时数、分钟数和秒数之间的差值。 2. 使用日期函数:也可以使用日期函数如“NUMTODSINTERVAL”和“NUMTOYMINTERVAL”函数来计算两个时间戳之间的差值,例如: ``` SELECT NUMTODSINTERVAL(timestamp2 - timestamp1, 'SECOND') AS diff FROM my_table; ``` 这将返回两个时间戳之间的差值,以秒为单位。 注意,在Oracle中,时间戳之间的差值将被表示为INTERVAL DAY TO SECOND或INTERVAL YEAR TO MONTH数据类型。 ### 回答2: 在Oracle中计算timestamp的时间差,可以使用函数来实现。以下是一种常见的方法: 1. 首先,使用TIMESTAMP类型的两个字段相减,可以得到它们之间的时间差,单位为天。 例如,如果有两个字段ts1和ts2,可以使用以下语句获取它们之间的时间差: ```sql SELECT ts2 - ts1 FROM table_name; ``` 2. 如果想获取具体的小时、分钟或秒数的时间差,可以使用EXTRACT函数来提取相应的时间部分。 以下是使用EXTRACT函数计算小时差的示例: ```sql SELECT EXTRACT(HOUR FROM (ts2 - ts1)) FROM table_name; ``` 3. 另外,如果需要获得更加精确的时间差,可以使用Oracle提供的INTERVAL数据类型。可以直接使用INTERVAL关键字来计算两个时间之间的时间差。 以下是计算两个timestamp类型字段之间时间差,并以月为单位显示的示例: ```sql SELECT ts2 - ts1 MONTH FROM table_name; ``` 通过使用上述方法之一,就可以在Oracle中计算timestamp的时间差。注意,在计算时间差时,要确保timestamp字段的有效性和正确格式。 ### 回答3: 在Oracle中,我们可以使用两个方法来计算timestamp的时间差。 第一种方法是使用TIMESTAMPDIFF函数。这个函数可以计算两个timestamp之间的差异,并返回以设定的时间单位表示的差异值。例如,我们可以使用以下语句计算两个timestamp之间的差异: SELECT TIMESTAMPDIFF(SECOND, t1, t2) AS 时间差 FROM 表名; 这将返回t1和t2之间的时间差,以秒为单位。 另一种方法是使用EXTRACT函数。这个函数可以从timestamp中提取日期或时间部分,并进行计算。我们可以使用以下语句来计算两个timestamp之间的差异: SELECT EXTRACT(DAY FROM (t2 - t1)) AS 天差, EXTRACT(HOUR FROM (t2 - t1)) AS 小时差, EXTRACT(MINUTE FROM (t2 - t1)) AS 分钟差, EXTRACT(SECOND FROM (t2 - t1)) AS 秒差 FROM 表名; 这将返回两个timestamp之间的天、小时、分钟和秒的差异。 无论是使用TIMESTAMPDIFF函数还是EXTRACT函数,我们都可以根据需要选择不同的时间单位来计算时间差。这些函数都可以有效地计算timestamp之间的时间差,以便我们可以在Oracle中进行时间相关的计算和操作。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值