Oracle 20c 新特性详解:SQL Macro 宏 SCALAR / TABLE 模式带来的敏捷和便利

导读:在 Oracle 20c 中,SQL的宏支持 - SQL Macro 为 SQL 开发带来了进一步的敏捷和便利,在这篇文章中,我们来详细了解一下 SQL Macro 的特性用法。

 

以下是概要介绍:

 

宏的作用在于让SQL获得进一步的概括和抽象能力,允许开发者将复杂的处理逻辑通过宏进行定义,然后在后续程序处理中可以反复引用这一定义。

 

在 20c 中引入的 SQL Macro 支持两种宏类型,Scalar 和 Table 类型。

SCALR 表达式可以用于 SELECT 列表、WHERE/HAVING、GROUP BY/ORDER BY子句;

TABLE 表达式可以用于 FROM 语句。

 

640?wx_fmt=jpeg

 

对于 SCALAR 类型的宏,可以为复杂的SQL提供更灵活的语法来优化执行,这些灵活的方式包括:包和Schema 级别的函数,重载,命名参数和默认参数。

 

通过SCALAR宏,可以使可重用的SQL代码对SQL Optimizer透明,这将带来很大的收益,包括:

– SQL优化器可以转换代码以有效执行;

– PL / SQL内部的查询可以合并到外部查询中;

–在PL / SQL和SQL之间没有上下文切换;

–在与外部查询相同的快照下执行 PL / SQL 函数内部的查询;

–使用标量宏的WHERE子句谓词可被下推到Exadata中的存储侧谓词评估– 这对PL / SQL函数不适用

 

640?wx_fmt=jpeg

 

我们看一个简单的示例,例如需要一个函数,返回数据的下限和上限,举例而言,如果 x < lower (特定小值) 则返回 lower(作为下限);如果 x > upper (特定大值)则返回 upper(作为上限),否则返回 x 本身。

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值