sunny123456

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

检查Oracle中是否是“数字”函数
原文链接:https://www.jb51.cc/oracle/207329.html

我试图检查来自oracle(10g)查询中的列的值是否是一个数字,以便进行比较。就像是:
  1. select case when ( is_number(myTable.id) and (myTable.id >0) )
  2. then 'Is a number greater than 0'
  3. else 'it is not a number'
  4. end as valuetype
  5. from table myTable

有任何想法如何检查?

假设myTable中的ID列没有声明为NUMBER(这似乎是一个奇怪的选择,可能是有问题的),你可以写一个函数,试图将(可能是VARCHAR2)ID转换为一个数字,捕获异常,并返回“Y”或“N”。就像是
  1. CREATE OR REPLACE FUNCTION is_number( p_str IN VARCHAR2 )
  2. RETURN VARCHAR2 DETERMINISTIC ParaLLEL_ENABLE
  3. IS
  4. l_num NUMBER;
  5. BEGIN
  6. l_num := to_number( p_str );
  7. RETURN 'Y';
  8. EXCEPTION
  9. WHEN value_error THEN
  10. RETURN 'N';
  11. END is_number;

然后,您可以将该调用嵌入查询中,即

  1. SELECT (CASE WHEN is_number( myTable.id ) = 'Y' AND myTable.id > 0
  2. THEN 'Number > 0'
  3. ELSE 'Something else'
  4. END) some_alias
  5. FROM myTable

注意,虽然PL / sql一个布尔数据类型,但sql不是。所以,虽然你可以声明一个函数返回一个布尔值,你不能在SQL查询中使用这样的函数

posted on 2023-09-11 10:08  sunny123456  阅读(230)  评论(0编辑  收藏  举报