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

news2025/1/27 13:08:04

  动态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程序。这种方法提高了代码的效率和可维护性。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux—进程与计划管理

目录 一、程序 二、进程 1、什么是进程 2、进程的特点 3、进程、线程、携程 3.1、进程 3.2、线程 3.3、携程 三、查看进程信息 1、ps -aux 2、ps -elf 3、top ​3.2、输出内容详解 3.2.1、输出第一部分解释 3.2.2、输出第二部分解释 4、pgrep 5、pstree 四、进…

从CVPR 2024看域适应、域泛化最新研究进展

域适应和域泛化一直以来都是各大顶会的热门研究方向。 域适应指&#xff1a;当我们在源域上训练的模型需要在目标域应用时&#xff0c;如果两域数据分布差异太大&#xff0c;模型性能就有可能降低。这时可以利用目标域的无标签数据&#xff0c;通过设计特定方法减小域间差异&a…

深入理解 Dubbo:分布式服务框架的核心原理与实践

目录 Dubbo 概述Dubbo 的架构Dubbo 的关键组件 服务提供者&#xff08;Provider&#xff09;服务消费者&#xff08;Consumer&#xff09;注册中心&#xff08;Registry&#xff09;监控中心&#xff08;Monitor&#xff09;调用链追踪&#xff08;Trace&#xff09; Dubbo 的…

减压电子陀螺MCU电子方案开发服务

指尖陀螺的功能主要是提供一种旋转的娱乐效果&#xff0c;其玩法包括单手拨转、花式旋转等。 指尖陀螺作为一种流行的小型玩具&#xff0c;其主要功能是利用轴承滚动原理达到旋转效果&#xff0c;为使用者提供视觉和触觉上的娱乐体验。玩指尖陀螺的基本方法是使用拇指和其他手…

网络流-EK算法(保姆级教学)

本文引用董晓算法的部分图片。 一些不能带入纸质资料的竞赛&#xff0c;网络流纳入考纲。 因为需要默写&#xff0c;想来也不会考默写dinic这种算法难倒大家&#xff0c;只需要快速敲对EK算法就行了。 EK算法能在O(n*m^2)的复杂度内解决最大流问题&#xff0c;其中最大流就是…

抖音外卖服务商有哪些,盘点这几家正规服务商!

当前&#xff0c;抖音外卖的关注度不断上涨&#xff0c;抖音外卖服务商也逐渐成为了众多创业者心中的理想创业赛道。在此背景下&#xff0c;抖音外卖服务商的入局途径多次引发创业者热议&#xff0c;以抖音外卖服务商有哪些公司为代表的相关话题更是长期位居创业者问题榜单的前…

WordPress Dokan Pro插件 SQL注入漏洞复现(CVE-2024-3922)

0x01 产品简介 WordPress Dokan Pro插件是一款功能强大的多供应商电子商务市场解决方案,功能全面、易于使用的多供应商电子商务平台解决方案,适合各种规模的电商项目。允许管理员创建一个多卖家平台,卖家可以注册账户并在平台上创建自己的店铺,展示和销售自己的产品。提供…

SecureCRT使用SSH登录服务器报错:Key exchange failed

SecureCRT使用SSH登录Ubuntu服务器报错&#xff1a;Key exchange failed 原因&#xff1a; ssh客户端与服务器的公钥协商失败&#xff0c;SecureCRT客户端所指定的秘钥交换算法&#xff08;KexAlgorithms &#xff09;&#xff0c;不在服务端支持范围内。可能是服务端的sshd版…

【代码随想录】【算法训练营】【第51天】 [115]不同的子序列 [583]两个字符串的删除操作 [72]编辑距离

前言 思路及算法思维&#xff0c;指路 代码随想录。 题目来自 LeetCode。 day 51&#xff0c;周四&#xff0c;又是不能坚持的一天~ 题目详情 [115] 不同的子序列 题目描述 115 不同的子序列 解题思路 前提&#xff1a; 思路&#xff1a; 重点&#xff1a; 代码实现 …

微信公众平台扫码登录:Spring Boot与JustAuth的完美结合

欢迎来到我的博客&#xff0c;代码的世界里&#xff0c;每一行都是一个故事 &#x1f38f;&#xff1a;你只管努力&#xff0c;剩下的交给时间 &#x1f3e0; &#xff1a;小破站 微信公众平台扫码登录&#xff1a;Spring Boot与JustAuth的完美结合 前言前提什么是JustAuthJust…

kali下安装使用蚁剑(AntSword)

目录 0x00 介绍0x01 安装0x02 使用1. 设置代理2. 请求头配置3. 编码器 0x00 介绍 蚁剑&#xff08;AntSword&#xff09;是一个webshell管理工具。 官方文档&#xff1a;https://www.yuque.com/antswordproject/antsword 0x01 安装 在kali中安装蚁剑&#xff0c;分为两部分&am…

python获取快手账号列表数据

快手数据获取相对简单访问地址固定且不需要登录token 列表地址获取的固定接口 https://www.kuaishou.com/graphql 发送post请求注意每个快手账号对应的id import time from datetime import datetime import logging import json import pymysql import requests# 创建一个lo…

vue3 【提效】自动导入框架方法 unplugin-auto-import 实用教程

是否还在为每次都需要导入框架方法而烦恼呢&#xff1f; // 每次都需手动导入框架方法 import { ref } from vuelet num ref(0)用 unplugin-auto-import 来帮你吧&#xff0c;以后只需这样写就行啦&#xff01; let num ref(0)官方示例如下图 使用流程 1. 安装 unplugin-au…

文物管理技术RFID技术

随着科技的不断发展&#xff0c;科技在各个领域都发挥着重要的作用。其中&#xff0c;在文物管理方面&#xff0c;RFID技术的应用正在逐渐引起人们的关注。RFID&#xff08;Radio Frequency Identification&#xff09;技术是一种通过无线电信号进行非接触式识别的技术&#xf…

【深度学习】Error: TensorBoard could not bind to port 6006 问题解决

问题描述 在启动TensorBoard时&#xff0c;遇到了端口冲突&#xff0c;如下图所示&#xff1a; 根据提示&#xff0c;出错原因是因为端口已经被占用了&#xff0c;因此我们要结束占用这个端口的进程。 我的系统是Windows系统&#xff0c;并不是Linux&#xff0c;网上大部分方…

基于springboot时装购物系统

设计技术&#xff1a; 开发语言&#xff1a;Java数据库&#xff1a;MySQL技术&#xff1a;SpringbootMybatisvue 工具&#xff1a;IDEA、Maven、Navicat 主要功能&#xff1a; 管理员&#xff1a;首页、个人中心、用户管理、商品分类管理、颜色管理、商品信息管理、商品评价…

以数治税时代来临,企业如何应对?

全电发票是数字经济时代发票的新形态&#xff0c;顺应了数字经济潮流。现如今&#xff0c;国家正全力推动行业数字化进程&#xff0c;预计&#xff0c;2025年将基本实现发票全领域、全环节、全要素电子化&#xff0c;实现税务执法、服务、监管与大数据智能化应用深度融合、高效…

数据库使用笔记

1.mysql数据库频繁访问导致连接超时 解决办法一&#xff1a; 优化查询&#xff1a;检查并优化SQL查询语句&#xff0c;减少不必要的数据库调用。增加连接池大小&#xff1a;如果应用程序使用连接池&#xff0c;可以考虑增加连接池的最大连接数。&#xff08;注&#xff1a;不能…

Profibus协议转Modbus协议网关模块在船舶中的应用

一、背景 在当今数字化快速发展的时代&#xff0c;船舶作为重要的交通工具之一&#xff0c;也在不断追赶着科技的步伐&#xff0c;实现自身的智能化升级。而在这个过程中&#xff0c;Profibus转Modbus网关&#xff08;XD-MDPB100&#xff09;作为关键的一环&#xff0c;扮演着…

主流先进封装技术介绍

主流先进封装技术介绍 先进封装是指封装集成电路 (IC) 以提高性能的多种创新技术。 本质上&#xff0c;就是将传统封装中被延缓的数据传输速度和被损耗的大量功耗&#xff0c;通过技术和结构的创新极大程度的找回。 1. FO 封装 FO封装包括三大类&#xff1a; 核心扇出型&a…