加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程 > 正文

pl/sql对回收数字名目标日期举办日期的转换

发布时间:2020-12-28 18:00:10 所属栏目:编程 来源:网络整理
导读:本日PHP站长网 52php.cn把网络自互联网的代码分享给各人,仅供参考。 --将用小数情势暗示的 日期时刻 转化为 天-小时-分钟-秒 的情势function fmt_time (p_days in number) return varchar2as l_days number; l_hours num

以下代码由PHP站长网 52php.cn网络自互联网

此刻PHP站长网小编把它分享给各人,仅供参考

--将用小数情势暗示的 日期时刻  转化为 天-小时-分钟-秒 的情势
function fmt_time (p_days in number) return varchar2
as
  l_days            number;
  l_hours           number;
  l_minutes         number;
  l_seconds         number;
  l_sign            varchar2(1);
  l_returnvalue     string_util_pkg.t_max_pl_varchar2;
begin

  /*

  Purpose:    get time formatted as days,hours,minutes,seconds

  Remarks:

  Who     Date        Description
  ------  ----------  -------------------------------------
  MBR     18.12.2006  Created

  */
  --通过传入的 日期得到响应的 各个单元数据
  --整数部门为 天
  l_days := nvl(trunc(p_days),0);
  --小数部门 *24 获得小时
  l_hours := nvl(((p_days - l_days) * 24),0);
  --得到的小时 数据的小数部门 *60 为分钟
  l_minutes := nvl(((l_hours - trunc(l_hours))) * 60,0);
  --同样的 将得到的 分钟的小数部门*60 为秒
  l_seconds := nvl(((l_minutes - trunc(l_minutes))) * 60,0);
  --判定日期正负 标记
  if p_days < 0 then
    l_sign:='minus ';
  else
    l_sign:='';
  end if;
  --将获得的数据 举办名目化  绝对值是为了举办须要的 去除正负号鉴定
  --得到天的绝对值
  l_days:=abs(l_days);
  --得到小时的绝对值 同时得到其整数部门
  l_hours:=trunc(abs(l_hours));
  --去取分钟的绝对值 然后四舍五入
  l_minutes:=round(abs(l_minutes));
  --去取秒的绝对值 然后四舍五入
  l_seconds:=round(abs(l_seconds));
  --假如分钟 为60  为什么会呈现这种环境呢? 这是由于有了四舍五入和小数 不准确所致
  if l_minutes = 60 then
    --则 让小时+1 同时分钟置空
    l_hours:=l_hours + 1;
    l_minutes:=0;
  end if;
  --将获得的功效 举办名目化输出
  --回收 天-》小时-》分钟的判定次序 是为了 可以或许抉择谁人 字段木有值
  if l_days > 0 then
    l_returnvalue:=string_util_pkg.get_str('%1 days,%2 hours,%3 minutes',l_days,l_hours,l_minutes);
  elsif l_hours > 0 then
    l_returnvalue:=string_util_pkg.get_str('%1 hours,%2 minutes,%3 seconds',l_minutes,l_seconds);
  elsif l_minutes > 0 then
    l_returnvalue:=string_util_pkg.get_str('%1 minutes,%2 seconds',l_seconds);
  else
    l_returnvalue:=string_util_pkg.get_str('%1 seconds',l_seconds);
  end if;
  --加上 标记
  l_returnvalue:=l_sign || l_returnvalue;

  return l_returnvalue;

end fmt_time;

以上内容由PHP站长网【52php.cn】网络清算供各人参考研究

假如以上内容对您有辅佐,接待保藏、点赞、保举、分享。

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读