Oracletimestamp类型增加值的问题

 我来答
青柠姑娘17
2022-11-07 · TA获得超过1.2万个赞
知道大有可为答主
回答量:6476
采纳率:100%
帮助的人:36.5万
展开全部

  在工作中我碰到这样一个问题 session表需要用到timestamp的字段 在进行timestamp字段更新时出现了为题 比如需要对session的有效期增加 小时

  采用 systimestamp + / 会丢失秒后的精度 感觉增加之后就变成了date型的样子 经过研究发现oracle 有个函数叫NUMTODSINTERVAL 可以解决这个问题 下面两个例子说明如何使用这个函数

  增加一小时

  SELECT to_char(systimestamp + NUMTODSINTERVAL( hour ) yyyy mm dd HH :mi:ss:ff ) to_char(systimestamp yyyy mm dd HH :mi:ss:ff ) FROM dual;

  增加一分钟

  SELECT to_char(systimestamp + NUMTODSINTERVAL( minut ) yyyy mm dd HH :mi:ss:ff ) to_char(systimestamp yyyy mm dd HH :mi:ss:ff ) FROM dual;

  对numtodesignterval的原版解释如下

  NUMTODSINTERVAL converts n to an INTERVAL DAY TO SECOND literal The argument n can be any NUMBER value or an expression that can be implicitly converted to a NUMBER value The argument interval_unit can be of CHAR VARCHAR NCHAR or NVARCHAR datatype The value for interval_unit specifies the unit of n and must resolve to one of the following string values:

   DAY

   HOUR

   MINUTE

   SECOND

lishixinzhi/Article/program/Oracle/201311/17416

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式