ABAP开发:动态Open SQL编程案例介绍

  动态Open SQL是Open SQL的扩展。它不是要求整个SQL语句都是动态指定的。通过熟悉的静态ABAP编码表达静态已知的部分,动态元素的部分通过动态标记指定。动态片段不明确包含在ABAP源代码中,而是源代码包含一个ABAP变量,用括号括起来作为占位符。程序必须包含创建动态片段的ABAP源代码的编码,并将其存储在该变量中。在运行时,动态片段的ABAP源代码被解析并混合到语句的静态部分中。动态和静态部分对数据库来说看起来像一个单一的语句。这个过程对数据库是完全透明的。

     以下通过两个程序案例来展示如何在ABAP中使用动态Open SQL来解决数据库访问问题。

案例一:动态表名
问题描述:用户需要查询一个数据库表,但表名在运行时才确定。

解决方案:使用动态Open SQL,我们可以在运行时动态构建SQL语句,包括表名和WHERE子句。

程序代码:

REPORT Y_DEMO_TEST_139.
data: tabname type tabname,
       count   type i.

start-of-selection.
  write: / 'SPFLI', / 'SFLIGHT', / 'SBOOK'.

at line-selection.
read current line line value into tabname.
select count(*) from (tabname) into count.
  write: 'The table', tabname(7), 'contains', count, 'entries.'

在SELECT语句中,数据库表的名称不是静态指定的。相反,子句from (tabname)表示数据库表的名称将从变量tabname中读取并替换到SELECT语句中:

 select count(*) from (tabname) INTO count.

在事件行选择时,所选行的内容被读入字段tabname中。

程序执行结果:

   在这个例子中,用户可以通过界面选择一个表名,程序会根据用户的选择动态构建SQL语句,并执行查询。

案例二:动态SELECT和GROUP BY子句

问题描述:用户需要根据选择的列和聚合条件,动态生成报表。

解决方案:通过动态Open SQL,我们可以在运行时动态构建SELECT和GROUP BY子句,以满足用户的需求。

程序代码:

type-pools abap.

  parameters: lt radiobutton group 1 default 'X',
  gt radiobutton group 1,
  value type i.

  data: begin of wa,
count type i.
include type spfli.
data: end of wa.

data: checked,
name type fieldname,
lines type i,
 descr_ref type ref to cl_abap_structdescr,
 sel_list type table of edpline,
 group_list type table of edpline,
having type string.

field-symbols: <fs> type any,
 <comp_wa> type abap_compdescr.

start-of-selection.

set pf-status 'MAIN'.

* get all components of table 'SPFLI'
 descr_ref ?=
 cl_abap_typedescr=>describe_by_name( 'SPFLI' ).

loop at descr_ref->components assigning <comp_wa>.
name = <comp_wa>-name.
 write: / checked as checkbox, name.
 endloop.
lines = lines( descr_ref->components ).

at user-command.

* determine selected columns
clear: sel_list, group_list.
 append 'count(*) as count' to sel_list.
do lines times.
read line sy-index field value checked.
if checked = 'X'.
read line sy-index field value name.
 append name to: sel_list, group_list.
 endif.
 enddo.

* determine operator
if gt = 'X'.
having = 'count(*) > value'.
 else.
having = 'count(*) < value'.
 endif.

select (sel_list)
from spfli up to 20 rows
into corresponding fields of wa
group by (group_list)
 having (having). 

* write all components to list
 write: / wa-count.
loop at group_list into name.
 assign component name of structure wa to <fs>.
 write: <fs>.
 endloop.
 endselect.

在程序代码16、17行中,
16          sel_list   type table of edpline,
17       group_list type table of edpline,
声明了两个内部表——sel_list和group_list——来保存动态SELECT和
GROUP BY子句的源代码:
代码的41到48行,在用户命令事件中,count()被添加到SELECT列表中作为第一个字段。别名count与工作区wa的组件count匹配。然后,从列表中提取复选框的值来确定所选的列。为此,我们循环遍历列表,并根据复选框的值将所选列的名称附加到sel_list和group_list中。因为SELECT列表包含聚合函数count(),所以我们必须在sel_list和group_list中包含所有列标识符: 


41   append 'count(*) as count' to sel_list.
42   do lines times.
43     read line sy-index field value checked.
44     if checked = 'X'.
45       read line sy-index field value name.
46       append name to: sel_list, group_list.
47     endif.
48   enddo.

接下来,根据group_list对数据进行分组,并根据having_clause
过滤中间结果集:

57   select (sel_list)
58       from spfli up to 20 rows
59       into corresponding fields of wa
60       group by (group_list)
61       having (having).

最后,将结果集按列显示:
63 * 写所有组件到列表
64     write: / wa-count.
65     loop at group_list into name.
66       assign component name of structure wa to <fs>.
67       write: <fs>.
68     endloop.
69   endselect.

为了成功执行,程序必须有一个GUI状态“MAIN”,它定义了一个带有功能代码“ONLI”的按钮,如下图:
  • 总之,结果随勾选字段的不同而不同。     

  • 在这个例子中,用户可以在界面上选择要包含在报表中的列,并设置聚合条件。程序会根据用户的选择动态构建SQL语句,并执行查询,生成报表。       

  • 动态Open SQL提供了一种强大的方法来处理在编译时无法确定的数据库访问问题,适合解决大多数需要通用数据库访问的编程情况。大多数Open SQL语句的子句——表名、SELECT、WHERE、GROUP BY、HAVING和ORDER BY——都可以动态指定。通过动态构建SQL语句的各个部分,我们可以编写出更加灵活和适应性强的ABAP程序。这种方法提高了代码的效率和可维护性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/749246.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【网络架构】lvs集群

目录 一、集群与分布式 1.1 集群介绍 1.2 分布式系统 1.3 集群设计原则 二、LVS 2.1 lvs工作原理 2.2 lvs集群体系架构 ​编辑 2.3 lvs功能及组织架构 2.4 lvs集群类型中术语 三、LVS工作模式和命令 3.1 lvs集群的工作模式 3.1.1 lvs的nat模式 3.1.2 lvs的dr模式 …

python-docx 使用xml为docx不同的章节段落设置不同字体

本文目录 前言一、完整代码二、代码详细解析1、处理过程解释(1) 引入库并定义路径(2) 创建docx的备份文件(3) 定义命名空间(4) 打开并处理.docx文件(5) 分析和组织文档结构(6) 设置字体(7) 保存结果前言 本文主要解决的内容,就是为一个docx的不同章节段落设置不同的字体,因为…

2024年公司加密软件排行榜(企业加密软件推荐)

在信息时代&#xff0c;企业数据安全至关重要&#xff0c;防止数据泄露和未授权访问是首要任务之一。以下是2024年备受好评的企业加密软件排行榜&#xff1a; 固信加密软件https://www.gooxion.com/ 1.固信加密软件 固信加密软件是新一代企业级加密解决方案&#xff0c;采用先…

7月开始,考研数学0️⃣基础线代30天满分规划

线代零基础&#xff1f; 那千万不要去跟李永乐老师的线代课程&#xff0c;因为李永乐老师的线代课程比较进阶&#xff0c;适合有一定基础的同学去听&#xff0c;下面这两位才是零基础线代的神&#xff01; 一个是喻老&#xff0c;另外一个是汤家凤&#xff01; 这两个老师的…

stencil 组件

stencil 组件 装饰器生命周期应用加载事件 组件定义组件如何响应数据变化 组件使用如何传递 slot如何暴露组件内部的方法供外部使用&#xff1f;Element 装饰器 Host 组件样式函数组件 stencil 提供一些装饰器、生命周期钩子和渲染函数去编写一个组件。 装饰器 装饰器是一组用…

Web网页端IM产品RainbowChat-Web的v7.0版已发布

一、关于RainbowChat-Web RainbowChat-Web是一套Web网页端IM系统&#xff0c;是RainbowChat的姊妹系统&#xff08;RainbowChat是一套基于开源IM聊天框架 MobileIMSDK (Github地址) 的产品级移动端IM系统&#xff09;。 ► 详细介绍&#xff1a;http://www.52im.net/thread-2…

【Sklearn驯化-回归指标】一文搞懂机器学习中回归算法评估指标:mae、rmse等

【Sklearn驯化-回归指标】一文搞懂机器学习中回归算法评估指标&#xff1a;mae、rmse等 本次修炼方法请往下查看 &#x1f308; 欢迎莅临我的个人主页 &#x1f448;这里是我工作、学习、实践 IT领域、真诚分享 踩坑集合&#xff0c;智慧小天地&#xff01; &#x1f387; 免…

大学计算机

项目一 了解计算机 1.1 了解计算机的诞生及发展阶段 1.2 认识计算机的特点、应用和分类 1&#xff0e;计算机的特点 1. 计算机的特点 2.计算机的应用 3.计算机的分类 4.数量单位 1.3 了解计算机操作系统的概念、功能与种类 1.操作系统概念 2.操作系统的作用 1&#xff0e…

Linux 中变量的取用与设定

优质博文&#xff1a;IT-BLOG-CN Linux是一个多人多任务的环境&#xff0c;每个人登录系统都能取得一个bash shell&#xff0c;每个人都能够使用bash下达mail这个指令来接收自己的邮箱等等。问题是&#xff0c;bash如何得知你的邮箱是那个文件&#xff1f;这就需要『变量』的帮…

jmeter性能测试

一.jmeter基本使用 1.元件执行顺序 配置元件&#xff1b; 前置处理器&#xff1b; 定时器&#xff1b; sampler&#xff1b; 后置处理器&#xff1b;&#xff08;关联&#xff0c;正则表达式提取器&#xff09; 断言&#xff1b; 监听&#xff1b;&#xff08;不涉及顺序&…

Windows 电脑类别怎么区分?不同类别区分总结

电脑类别 Windows 电脑的类别有哪些&#xff1f;我们可以大致分为这三类&#xff1a;CopilotPC、AI PC、普通 PC。下面就来看看这些电脑类别的区别。 普通 PC 普通 PC 就是指那些标准的台式电脑或者笔记本电脑&#xff0c;它们是由中央处理器&#xff08;CPU&#xff09;以及…

【面试题】信息安全风险评估要做些什么

信息安全风险评估是识别、评估和管理信息系统中潜在风险的重要过程。它具有以下几个关键步骤&#xff1a; 1.资产识别&#xff1a; 确定需要保护的信息资产&#xff0c;如硬件、软件、数据、人员等。例如&#xff0c;企业的客户数据库、重要的业务文档等。 2.威胁评估&#…

手把手教你打造高精度STM32数字时钟,超详细步骤解析

STM32数字时钟项目详解 1. 项目概述 STM32数字时钟是一个集成了时间显示、闹钟功能、温湿度检测等多功能于一体的小型电子设备。它利用STM32的实时时钟(RTC)功能作为核心,配合LCD显示屏、按键输入、温湿度传感器等外设,实现了一个功能丰富的数字时钟系统。 2. 硬件组成 STM…

文献解读-基因编辑-第十二期|《CRISPR-detector:快速、准确地检测、可视化和注释基因组编辑事件引起的全基因组范围突变》

关键词&#xff1a;基因组变异检测&#xff1b;全基因组测序&#xff1b;基因编辑&#xff1b; 文献简介 标题&#xff08;英文&#xff09;&#xff1a;CRISPR-detector: fast and accurate detection, visualization, and annotation of genome-wide mutations induced by g…

做外贸有些事说早了,未必是好事

如果说能说话&#xff0c;其实谁也会&#xff0c;但是能把话说好却并不是一个简单的事&#xff0c;而且说话的时机往往也影响着事情的结局和走向&#xff0c; 所以才有了老人常提起的那句话&#xff1a;三岁学说话&#xff0c;一生学闭嘴。 最近我又因为图省事而犯了一个错误&…

云通SIPX,您的码号资源智能调度专家!

在数字化转型的浪潮中&#xff0c;号码资源作为企业与客户沟通的重要桥梁&#xff0c;其管理效率直接关系到企业运营的成败。随着运营商对号码资源管理的规范化和精细化&#xff0c;企业对高效、智能的号码资源管理需求日益增长&#xff0c;以实现对外呼叫的降本增效。 一、什么…

JAVA编程题期末题库【中】

8.计算邮资 程序代码: public static void main(String[] args) {// 计算邮资//if多分支语句//创建对象java.util.Scanner inputnew java.util.Scanner(System.in); //提示输入用户&#xff0c;输入邮件的重量System.out.println("邮件的重量&#xff1a;");int wei…

VMware ESXi 8.0U2c macOS Unlocker OEM BIOS Huawei (华为) FusionServer 定制版

VMware ESXi 8.0U2c macOS Unlocker & OEM BIOS Huawei (华为) FusionServer 定制版 ESXi 8.0U2 标准版&#xff0c;Dell (戴尔)、HPE (慧与)、Lenovo (联想)、Inspur (浪潮)、Cisco (思科)、Hitachi (日立)、Fujitsu (富士通)、NEC (日电)、Huawei (华为)、xFusion (超聚…

小型智能驱鸟器,建筑驱鸟专用

随着城市化进程的加快&#xff0c;鸟类与人类的居住空间逐渐交织重合&#xff0c;鸟类对建筑物的侵扰问题也愈发凸显。家庭庭院、住宅窗前、屋顶&#xff0c;甚至那些承载着历史与文化底蕴的名胜古迹和精美雕像&#xff0c;都时常受到鸟粪的污染。鸟粪具有腐蚀性且很难清理&…

智能疏散指示系统为什么是验收的必然考核标准?哪些厂家具备资质

智能疏散系统需要什么&#xff1f;现阶段&#xff0c;随着我国经济不断发展趋势的加快&#xff0c;住宅建筑具有复杂的特点。近年来&#xff0c;我国高层住宅、大中型建筑、综合性公共建筑越来越多。随着这座现代建筑的进步&#xff0c;我发现这种类型的建筑在发生火灾或事故时…