oracle 02000,Error: ORA-02000: missing ( keyword

This is my query.

ALTER TABLE My_employees ADD (Age number(3) GENERATED ALWAYS AS ROUND(MONTHS_BETWEEN(SYSDATE,hire_date)/12)+23 VIRTUAL)

Ok - and that is supposed to compute 'Age'?Is there anything wrong in my query.

Yes

1. How can 'age' be based on someone's 'hire_date'?

2. How can 'age' be computed accurately by adding '23' to the result?

That 'correct' answer may appear to work fine since it can give the 'correct' answer a lot of the time. After all, even if SYSDATE changes during the execution of the query you are only concerned with MONTHS and the month of sysdate is rarely going to change during the execution of one query.

The sysdate 'month' might change if the query runs overnight. Even then your computed 'age' would only change by one month.

But it can also change if any CACHING occurs such as result set caching or function caching and 24x7 systems could cache data for a LONG time.

As others have stated specifying DETERMINISTIC for a function that is NOT poses a risk. It is your database so you are free to take whatever level of risk you desire just as folks that do NOT using archiving have decided to take risks.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值