前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >Oracle Database 23ai 中的 SQL Transpiler

Oracle Database 23ai 中的 SQL Transpiler

作者头像
Yunjie Ge
发布于 2025-03-27 09:02:42
发布于 2025-03-27 09:02:42
8500
代码可运行
举报
文章被收录于专栏:数据库与编程数据库与编程
运行总次数:0
代码可运行

在 Oracle Database 23ai 中,引入了一项非常有价值的功能 —— SQL Transpiler。该功能旨在通过将 PL/SQL 函数自动转换为 SQL 表达式,来减少 SQL 查询中函数调用的开销,使得数据库在处理复杂查询时能够更高效地利用底层执行引擎,提高查询执行效率,从而在复杂数据处理场景下获得更好的性能表现。无论是在单实例环境还是在多实例(如 RAC)环境中,该功能都为开发者提供了灵活的性能调优工具。对于那些依赖大量函数调用的应用程序来说,合理利用 SQL Transpiler 不仅能降低系统资源消耗,还能显著提升整体响应速度,是一个非常值得关注的优化特性。

功能优势

在传统的数据库开发过程中,很多开发者习惯于将业务逻辑写在 PL/SQL 中,借助存储过程、函数来实现数据计算和处理。然而,PL/SQL 与 SQL 查询之间的切换往往会带来额外的性能消耗。Oracle 23ai 中的 SQL Transpiler 就是为了解决这一问题而设计的。通过自动转换 PL/SQL 函数为 SQL 表达式,数据库引擎可以直接在 SQL 级别处理计算逻辑,从而降低函数调用的额外开销,同时还使查询优化器能够更好地优化执行计划。

具体来说,SQL Transpiler 能够在无需用户过多干预的情况下,将在 SQL 查询中调用的某些 PL/SQL 函数进行转换。这样一来,原本复杂的函数调用就可以被简化为标准的 SQL 算术运算或其他 SQL 表达式,大大提升了 SQL 查询的执行速度和整体响应能力。

参数说明

Oracle Database 为 SQL Transpiler 提供了一个名为 SQL_TRANSPILER 的初始化参数。该参数可以在会话级别或系统级别进行设置,以便灵活控制 SQL Transpiler 的启用状态。

当该参数设置为 ON 时,Oracle 数据库会自动尝试将存储在数据库中的 PL/SQL 函数转换为 SQL 表达式;而设置为 OFF 则表示禁用这一转换功能。在多实例环境中,如 Oracle RAC,不同的实例可以根据实际需求分别启用或禁用 SQL Transpiler,从而实现灵活的资源调度和负载均衡

转换机制

SQL Transpiler 主要针对那些在 SQL 查询中经常被调用的 PL/SQL 函数。通过分析函数内部的逻辑,系统会判断是否可以将其直接转换为 SQL 运算。例如,如果函数内仅包含简单的算术运算或字符串处理,SQL Transpiler 就会将其转换为相应的 SQL 表达式。这样不仅能够减少上下文切换带来的性能损耗,还能使查询计划更加简洁明了,便于数据库优化器进行更高效的执行计划生成。

在转换过程中,Oracle 会对函数内部的表达式进行语义分析和安全性检查,确保转换后的 SQL 表达式在逻辑上与原有的 PL/SQL 函数保持一致,并且不会引入潜在的安全隐患或错误。

示例

在实际应用中,SQL Transpiler 的优势在于其能够简化对存储过程和函数的调用逻辑,尤其是在数据量较大或查询复杂度较高的情况下,其优化效果尤为明显。

初始化数据:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
drop table if exists test1;
create table t1 (
  id    number,
  col1  number,
  col2  number
);
insert into t1 (id, col1, col2)
values (1, 1, 2), (2, 10, 20), (3, 100, 200);
commit;

以下示例展示了在未启用和启用 SQL Transpiler 时查询执行计划的对比:

未启用 SQL Transpiler 时:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
select id, col1, col2 from   test1
where  add_numbers(col1, col2) = 300;


select * from   dbms_xplan.display_cursor();

SQL_ID  f38z6t91fvrun, child number 0
-------------------------------------
select id, col1, col2 from   test1 
where  add_numbers(col1, col2) = 300

Plan hash value: 4122059633

---------------------------------------------------------------------------
| Id  | Operation         | Name  | Rows  | Bytes | Cost (%CPU)| Time     |
---------------------------------------------------------------------------
|   0 | SELECT STATEMENT  |       |       |       |     3 (100)|          |
|*  1 |  TABLE ACCESS FULL| TEST1 |     1 |    39 |     3   (0)| 00:00:01 |
---------------------------------------------------------------------------

Predicate Information (identified by operation id):
---------------------------------------------------

   1 - filter("ADD_NUMBERS"("COL1","COL2")=300)

Note
-----
   - dynamic statistics used: dynamic sampling (level=2)

在上述示例中,查询中直接调用了 ADD_NUMBERS 函数,因此在执行计划中仍然可以看到对该函数的调用,从而增加了额外的计算开销。

启用 SQL Transpiler 后:

为了验证 SQL Transpiler 的效果,我们可以通过修改会话参数为 ON 来启用这一功能:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
alter session set sql_transpiler = 'ON';

select id, col1, col2 from  test1
where  add_numbers(col1, col2) = 300;

select * from   dbms_xplan.display_cursor();

PLAN_TABLE_OUTPUT
----------------------------------------------------------------------------------------------------
SQL_ID  dcttgua9qy5x4, child number 0
-------------------------------------
select id, col1, col2 from  test1 
where  add_numbers(col1, col2) = 300

Plan hash value: 4122059633

-------------------------------------------------------------------------------
| Id  | Operation         | Name      | Rows  | Bytes | Cost (%CPU)| Time     |
-------------------------------------------------------------------------------
|   0 | SELECT STATEMENT  |           |       |       |     3 (100)|          |
|*  1 |  TABLE ACCESS FULL| TTEST11   |     1 |    39 |     3   (0)| 00:00:01 |
-------------------------------------------------------------------------------

Predicate Information (identified by operation id):
---------------------------------------------------

   1 - filter("COL1"+"COL2"=300)

Note
-----
   - dynamic statistics used: dynamic sampling (level=2)


22 rows selected.

SQL>

可以看到,启用 SQL Transpiler 后,原来通过函数 ADD_NUMBERS 实现的计算逻辑已经被转换为直接的 SQL 表达式 "COL1" + "COL2"=300。这一转换有效消除了函数调用的额外成本,从而有助于简化执行计划和提高查询性能。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2025-03-25,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 山东Oracle用户组 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Tomcat安全配置小技巧
1.版本:应该从Tomcat官方提供的下载页面下载最新稳定版本,注意不要下载beta版本。Tomcat官网地址为: http://tomcat.apache.org/ 2.使用非root启动:Tomcat禁止以系统root账户启动,需新建普通用户用于启动Tomcat。检查tomcat启动进程账户可以通过ps aux | grep tomcat命令查看。 直接使用非root用户启动tomcat,适用tomcat5/6/7/8,只能监听1024以上的端口,如8080。操作方案步骤如下: 第一步:新建用户 use
腾讯云安全
2018/06/12
2K0
Tomcat 安全基线检查
描述 tomcat-manger是Tomcat提供的web应用热部署功能,该功能具有较高权限,会直接控制Tomcat应用,应尽量避免使用此功能。如有特殊需求,请务必确保为该功能配置了强口令 加固建议 编辑Tomcat根目录下的配置文件conf/tomcat-user.xml,修改user节点的password属性值为复杂密码, 密码应符合复杂性要求:
咻一咻
2020/05/29
1.8K0
web.xml基本配置。
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance
用户1220053
2018/04/17
6650
Tomcat 性能优化
Sun 公司创建了第一个 Servlet 容器,即 Java Web Server,但 JWS 只是为了演示 Servlet 的相应功能,所以其性能很不稳定。与此同时,apache 基金会组织 (ASF) 创建了 JServ 项目,一个能够与 apache 整合起来的 servlet 容器。
CSDN技术头条
2018/07/30
7570
Tomcat卷五---Web 应用配置,管理配置和JVM配置
web.xml 是web应用的描述文件, 它支持的元素及属性来自于Servlet 规范定义 。
大忽悠爱学习
2022/05/09
6680
Tomcat卷五---Web 应用配置,管理配置和JVM配置
tomcat安全加固
【加固方法】删除webapps/docs、examples、manager、ROOT、host-manager
程序员同行者
2018/07/24
9930
DevOps: Tomcat安全管理规范
随着公司内部使用Tomcat作为web应用服务器的规模越来越大,为保证Tomcat的配置安全,防止信息泄露,恶性攻击以及配置的安全规范,特制定此Tomcat安全配置规范。
Freedom123
2024/03/29
1190
DevOps: Tomcat安全管理规范
Tomcat安全加固与性能优化
为了更好的指导部署Tomcat应用容器,保证服务的安全稳定高性能的运行,需要对其进行加固和优化; 本次进行Tomcat容器调优加固主要从以下几个部分:
全栈工程师修炼指南
2022/09/29
2.5K0
Tomcat安全加固与性能优化
Tomcat优化实例详解
以下配置如无特别指明,默认为在/usr/local/tomcat8/conf/server.xml文件中配置
星哥玩云
2022/07/27
3340
企业级Tomcat安全管理优化方案
telnet管理端口保护 1. 修改默认的8005管理端口为不易猜测的端口(大于1024); <Server port="8527" shutdown="dangerous"> 2. 修改SHUTDOWN指令为其他字符串; ajp连接端口保护 1. 修改默认的ajp 8009端口为不易冲突的大于1024端口; 2. 通过iptables规则限制ajp端口访问的权限仅为线上机器; <Connector port="8528" protocol="AJP/1.3" /> 保护此端口的目的在于防止线下的测试流量
863987322
2018/01/24
8520
【安全加固】Apache Tomcat服务安全加固
Tomcat启动用户权限必须为非root权限、尽量降低tomcat启动用户的目录访问权限。
腾讯云-MSS服务
2021/01/11
2.9K0
Tomcat下部署vue项目[history模式]
第一种: IP+端口直接访问的方式,如 http://192.168.1.107:8080/ 第二种:IP+端口+项目名,如 http://192.168.1.107:8080/saas/
leader755
2022/03/07
3.4K0
Tomcat下部署vue项目[history模式]
详解tomcat 9 安全加固方法
关闭后,bin/shutdown.sh 就失效了,提示SEVERE: No shutdown port configured. Shut down server through OS signal. Server not shut down.
IT运维技术圈
2022/08/18
2.1K0
Tomcat_04_安全优化
1. 配置部分(**${ CATALINA_HOME }conf/server.xml**)
Cyylog
2020/08/19
4030
Tomcat 安全配置与性能优化
Tomcat 安全配置与性能优化 目录 1. JVM 1.1. 使用 Server JRE 替代JDK。 1.2. JAVA_OPTS 2. Tomcat 优化 2.1. maxThreads 连接数限制 2.2. 虚拟主机 2.3. 压错传输 3. Tomcat 安全配置 3.2.1. 隐藏版本信息 3.2.2. 应用程序安全 3.2.3. JSESSIONID 3.1. 禁用8005端口 3.2. 安装后初始化配置 3.3. 启动用户与端口 4. 如何部署应用程序 1. JVM 1.1. 使用 Serv
netkiller old
2018/03/05
1.1K0
公司web安全等级提升
公司的一个web数据展示系统,本来是内网的,而且是一个单独的主机,不存在远程控制的问题,所以之前并没有考虑一些安全相关的测试.但是国调安全检查的需要添加这样子的一层防护措施,所以还是不得不添加一下. 仔细想一下,如果内网机被人意外连接网线,确实是会存在被入侵的可能,所以还是添加一下为好.
@坤的
2018/09/21
1.8K0
Servlet进阶开发
获取请求属性: Object attr = request.getAttribute(属性名)
Breeze.
2022/07/12
3710
Servlet进阶开发
Spring思维导图,让Spring不再难懂(mvc篇)
在前面 生活就像海洋,只有意志坚强的人才能到达彼岸。已经很久没有发文章了呀,想必大家都挂念我了,哈哈。温故而知新,今天一起来复习一下spring mvc的内容吧。 spring mvc简介与运行原理
java思维导图
2018/03/15
1.2K0
Spring思维导图,让Spring不再难懂(mvc篇)
Resin安全配置小技巧
1.版本:应该从Resin官方提供的下载页面下载最新稳定 版本,注意不要下载beta版本。Resin官网地址为: http://www.caucho.com/download/ 2.删除默认页面:R
腾讯云安全
2018/06/12
2K0
Tomcat安全加固与防护实践(6个方法)
1) 出于稳定性考虑,不建议进行跨版本升级,如果之前是6.0系列版本,最好还是使用该系列的最新版本。
牛油果
2019/07/31
2.5K0
Tomcat安全加固与防护实践(6个方法)
相关推荐
Tomcat安全配置小技巧
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验