oracle case when Error:Ora-06592 Case語句時未找到case

來源:互聯網
上載者:User

昨天遇到一個很鬱悶的問題,寫了一個oracle 的function SQL如下

Code
 1CREATE OR REPLACE FUNCTION CALCs1(Lf NUMBER)
 2RETURN NUMBER AS
 3S1 NUMBER;
 4K NUMBER;
 5BEGIN
 6   CASE
 7      WHEN Lf>0.92 THEN K :=0;
 8      WHEN Lf>0.75 AND Lf<=0.92 THEN K :=(1.257407-2.44079*Lf+1.320967*Lf*Lf);
 9      WHEN Lf<=0.75 THEN K :=0.17;
10       else K :=0;--這是後來加的
11   END CASE;
12   S1 :=(1+K*(0.92-Lf)/Lf);
13   --dbms_output.put_line('Lf='||lf||'K='||K||'  S1='||S1);
14 RETURN S1;
15 EXCEPTION
16    WHEN INVALID_NUMBER THEN
17    RETURN 0;
18END;

寫完後測試了一下通過了,但是在調用的時候總是出現這樣的錯誤

看了半天也沒有發現case when 有什麼問題,問題到底出在那裡列

在這裡找到了答案http://www.error-code.org.uk/view.asp?e=ORACLE-ORA-06592

case when 需要有else

不明白我為什麼建立成功了測試一下結果也計算出來了,就是調用的時候出這個錯

記下來,免得以後再犯這樣的錯。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.