ABAP 中使用 Native SQL 进行大小写模糊查询

Open SQL 允许我们访问在 ABAP 字典中声明的数据库表,而不管您使用的数据库平台如何。通常开发都是直接用这种 SQL 查询语句,可以查看我之前的文章。

而 Native SQL (原生 SQL )允许我们在 ABAP 程序中使用特定于数据库的 SQL 语句。这意味着您可以使用不受 ABAP 字典管理的数据库表,从而集成不属于 SAP Web AS ABAP 系统的数据。

通常,包含特定于数据库的 SQL 语句的 ABAP 程序不会在不同的数据库系统下运行。如果程序将在多个数据库平台上使用,请仅使用 Open SQL 语句。

ABAP 程序中的 Native SQL

想要在 ABAP 程序中使用原生 SQL 语句,必须在前面加上 EXEC SQL 语句,并在查询的最后加上 ENDEXEC 语句,语法如下:

ABAP 复制代码
EXEC SQL [PERFORMING form].  

<Native SQL>

ENDEXEC.

Native SQL 语句后没有句点 (.)。此外,在 Native SQL 语句中使用双引号 ( " ) 或在行首使用星号 (*) 不会像在普通 ABAP 语法中那样变成注释。同时,我们还需要知道表和字段名称在所查询的数据库中是否区分大小写

在 Native SQL 语句中,使用主机变量在数据库表和 ABAP 程序之间传输数据。这些变量在 ABAP 程序中声明,并在本机 SQL 语句前面加上冒号 (:)。可以使用基本结构作为主变量。在特殊情况下,INTO 子句中的结构被视为单独列出其所有字段。

如果本机 SQL SELECT 语句中的选择是表,则可以使用 PERFORMING 条件将其逐行传递给 ABAP。程序为读取的每一行调用一个子例程表单。您可以在子例程中进一步处理数据。

与在 Open SQL 中一样,sy-dbcnt 包含语句 ENDEXEC 之后的已处理行数。sy-subrc 在几乎所有情况下都在语句 ENDEXEC 之后值 0,游标操作除外:在 FETCH 之后,sy-subrc 可能会读取更多记录。当您使用 EXEC SQL PERFORMING 读取结果集时,这也适用。


大小写模糊查询

最近接到用户需求,想要通过供应商名称进行模糊查询,不论输入的是大写还是小写,能同时把大小写名称符合的匹配出来。

我心想这不是很容易吗,然后就用了下面的 SQL 语句,谁知道根本就没有这语法,激活就报错:

ABAP 不支持下面的语法:

SQL 复制代码
SELECT DISTINCT lifnr name1 name2 FROM lfa1  
 WHERE LOWER( name1 ) LIKE @search_term  
 INTO TABLE @lt_lfa1.

这条语句是会报错的,ABAP OPEN SQL 没有这种类似的 SQL 的语法,但可以使用如下代码:

ABAP 复制代码
REPORT zupper_lower.  
TABLES lfa1.  
DATA: BEGIN OF ls_lfa1,  
        lifnr TYPE lfa1-lifnr,  
        name1 TYPE lfa1-name1,  
        mcod1 TYPE lfa1-mcod1,  
      END OF ls_lfa1.  
DATA: lt_lfa1 LIKE TABLE OF ls_lfa1.  
  
" lower case  
DATA: search_term TYPE string.  
  
PARAMETERS: p_name(200) TYPE c LOWER CASE.  
  
search_term =  |%{ to_lower( p_name ) }%|.  
  
  
  
*SELECT DISTINCT lifnr name1 name2 FROM lfa1  
* WHERE lower( name1 ) LIKE @search_term  
* INTO TABLE @lt_lfa1.  
  
EXEC SQL PERFORMING loop_output.  
  SELECT lifnr, name1, mcod1  
    INTO :ls_lfa1  
    FROM lfa1  
 WHERE LOWER(name1) LIKE :search_term  
ENDEXEC.  
  
FORM loop_output.  
  APPEND ls_lfa1 TO lt_lfa1.  
ENDFORM.  
  
START-OF-SELECTION.  
  PERFORM show_data.  
  
*&---------------------------------------------------------------------*  
*&      Form  SHOW_DATA  
*&---------------------------------------------------------------------*  
*       text  
*----------------------------------------------------------------------*  
*  -->  p1        text  
*  <--  p2        text  
*----------------------------------------------------------------------*  
FORM show_data .  
  IF lt_lfa1 IS NOT INITIAL.  
  
*  APPEND lfa1 TO lt_lfa1.  
    cl_demo_output=>display( lt_lfa1 ).  
  
  ELSE.  
  
    WRITE : 'search failed!'.  
  
  ENDIF.  
ENDFORM.

运行程序,结果如下:

参考链接:Native SQL

相关推荐
踏浪无痕19 小时前
AI 时代架构师如何有效成长?
人工智能·后端·架构
程序员小假19 小时前
我们来说一下无锁队列 Disruptor 的原理
java·后端
武子康20 小时前
大数据-209 深度理解逻辑回归(Logistic Regression)与梯度下降优化算法
大数据·后端·机器学习
maozexijr21 小时前
Rabbit MQ中@Exchange(durable = “true“) 和 @Queue(durable = “true“) 有什么区别
开发语言·后端·ruby
源码获取_wx:Fegn089521 小时前
基于 vue智慧养老院系统
开发语言·前端·javascript·vue.js·spring boot·后端·课程设计
独断万古他化21 小时前
【Spring 核心: IoC&DI】从原理到注解使用、注入方式全攻略
java·后端·spring·java-ee
毕设源码_郑学姐21 小时前
计算机毕业设计springboot基于HTML5的酒店预订管理系统 基于Spring Boot框架的HTML5酒店预订管理平台设计与实现 HTML5与Spring Boot技术驱动的酒店预订管理系统开
spring boot·后端·课程设计
不吃香菜学java21 小时前
spring-依赖注入
java·spring boot·后端·spring·ssm
ja哇21 小时前
Spring AOP 详细讲解
java·后端·spring
南部余额21 小时前
Spring Boot 整合 MinIO:封装常用工具类简化文件上传、启动项目初始化桶
java·spring boot·后端·文件上传·工具类·minio·minioutils