如何在 SELECT 语句中使用 BOOLEAN 类型

How to use BOOLEAN type in SELECT statement(如何在 SELECT 语句中使用 BOOLEAN 类型)
本文介绍了如何在 SELECT 语句中使用 BOOLEAN 类型的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一个参数为 BOOLEAN 的 PL/SQL 函数:

I have a PL/SQL function with BOOLEAN in parameter:

function get_something(name in varchar2, ignore_notfound in boolean);

此功能是第三方工具的一部分,我无法更改.

This function is a part of 3rd party tool, I cannot change this.

我想在像这样的 SELECT 语句中使用这个函数:

I would like to use this function inside a SELECT statement like this:

 select get_something('NAME', TRUE) from dual;

这不起作用,我收到此异常:

This does not work, I get this exception:

ORA-00904:TRUE":无效标识符

ORA-00904: "TRUE": invalid identifier

据我所知,无法识别关键字 TRUE.

As I understand it, keyword TRUE is not recognized.

我怎样才能做到这一点?

How can I make this work?

推荐答案

你可以像这样构建一个包装函数:

You can build a wrapper function like this:

function get_something(name in varchar2,
                   ignore_notfound in varchar2) return varchar2
is
begin
    return get_something (name, (upper(ignore_notfound) = 'TRUE') );
end;

然后调用:

select get_something('NAME', 'TRUE') from dual;

您的版本中 ignore_notfound 的有效值是什么取决于您,我假设TRUE"表示 TRUE,其他任何表示 FALSE.

It's up to you what the valid values of ignore_notfound are in your version, I have assumed 'TRUE' means TRUE and anything else means FALSE.

这篇关于如何在 SELECT 语句中使用 BOOLEAN 类型的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Execute complex raw SQL query in EF6(在EF6中执行复杂的原始SQL查询)
Hibernate reactive No Vert.x context active in aws rds(AWS RDS中的休眠反应性非Vert.x上下文处于活动状态)
Bulk insert with mysql2 and NodeJs throws 500(使用mysql2和NodeJS的大容量插入抛出500)
Flask + PyMySQL giving error no attribute #39;settimeout#39;(FlASK+PyMySQL给出错误,没有属性#39;setTimeout#39;)
auto_increment column for a group of rows?(一组行的AUTO_INCREMENT列?)
Sort by ID DESC(按ID代码排序)