sunny123456

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::
  1796 随笔 :: 22 文章 :: 24 评论 :: 226万 阅读
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

检查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   sunny123456  阅读(269)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)
历史上的今天:
2022-09-11 centos7系统的ping命令出现 www.baidu.com Name or service not known
2022-09-11 centos7 network-manager 与 interfaces 冲突 ,实际未成功,
点击右上角即可分享
微信分享提示