利用 NATIVE SQL 实现不区分供应商名字大小写进行模糊查询

公司有个需求 ,当按用英文名字来进行查询时,可以实现不区分供应商名字大小写进行模糊查询。

例如:如果用户输入'br' 那么可以查出名字含有 'BR'、'bR'、'Br' 、'br' 的供应商来。利用SAP 常规的 Open SQL 是实现不了的。 只能利用 Native SQL 语句。

在SAP 官网有这个资料,同学们可以过去学习一下:

Native SQL (SAP Library - ABAP Programming (BC-ABA))

我首先测试了下面种方式,这种方式可以写在 ABAP 程序里,但写在RFC不行。

Native SQL Statements in ABAP Programs

复制代码
REPORT demo_native_sql.

DATA: BEGIN OF wa,
        connid   TYPE spfli-connid,
        cityfrom TYPE spfli-cityfrom,
        cityto   TYPE spfli-cityto,
      END OF wa.

DATA c1 TYPE spfli-carrid VALUE 'LH'.

EXEC SQL PERFORMING loop_output.
  SELECT connid, cityfrom, cityto
  INTO   :wa
  FROM   spfli
  WHERE  carrid = :c1
ENDEXEC.

FORM loop_output.
  WRITE: / wa-connid, wa-cityfrom, wa-cityto.
ENDFORM.

然后我用了游标的方式。

复制代码
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.
  DATA: search_term TYPE string.

  IF i_name  is not INITIAL .


  search_term =  |%{ to_lower( i_name ) }%|.
*

"  利用  NATIVE  SQL  进行 按供应商名字不区分大小写查询
  EXEC SQL.
    OPEN c1 FOR
   SELECT lifnr, name1 

      FROM lfa1
   WHERE LOWER(name1) LIKE :search_term
   and   MANDT = :SY-MANDT
  ENDEXEC.
  DO.
    EXEC SQL.
      FETCH NEXT c1 INTO :ls_lfa1
    ENDEXEC.
    IF sy-subrc <> 0.
      EXIT.
    ELSE.
      APPEND ls_lfa1 TO lt_lfa1.
    ENDIF.
  ENDDO.
  EXEC SQL.
    CLOSE c1
  ENDEXEC.

  ENDIF.

最后结果呈现如下: 用户输入 br

相关推荐
夫礼者2 小时前
【极简监控】选连接池送深度监控?用 Druid 补齐单体应用全局 SQL 统计的最后拼图
java·数据库·sql·druid
码农学院2 小时前
一些在平常开发过程中会用到的比较经典的 SQL 语句,常常用于实现一些很特别的功能。
数据库·sql
vortex52 小时前
原创 Burp 插件 | Injector - Path Collector:专攻 URL 路径与 XFF 头部 SQL 注入
数据库·sql·网络安全·渗透测试
sensen_kiss2 小时前
CAN302 Technologies for E-Commerce 电子商务技术 Pt.4 深入了解PHP和SQL
开发语言·sql·php
xcLeigh3 小时前
KES数据库数据类型与SQL高级语法
大数据·数据库·sql·kes·高级语法·数据选型
本体智能12 小时前
预制指标、宽表、SQL、本体ABC:真正决定长期成本的,是一次变更会波及多少层
数据库·sql·本体神经网络·uino数据智能引擎
淼淼爱喝水16 小时前
DVWA SQL 注入(Medium/High 级别)过滤绕过与防范实验(超详细图文版)
数据库·sql·网络安全
野生技术架构师19 小时前
掌握SQL窗口函数,轻松处理复杂数据分析
数据库·sql·数据分析
admin and root20 小时前
从资产收集FUZZ接口到SQL注入案例
网络·数据库·sql·安全·web安全·渗透测试·log4j
小陈工20 小时前
Python Web开发入门(十):数据库迁移与版本管理——让数据库变更可控可回滚
前端·数据库·人工智能·python·sql·云原生·架构