「SAP ABAP」OPEN SQL的DML语句你了解多少 (附超详细案例讲解)
创始人
2025-05-28 06:01:43
0

在这里插入图片描述

💂作者简介: THUNDER王,一名热爱财税和SAP ABAP编程以及热爱分享的博主。目前于江西师范大学本科在读,同时任汉硕云(广东)科技有限公司ABAP开发顾问。在学习工作中,我通常使用偏后端的开发语言ABAP,SQL进行任务的完成,对SAP企业管理系统,SAP ABAP开发和数据库具有较深入的研究。


💅文章概要: 各位小伙伴们大家好呀!今天继续SAP ABAP系列文章的讲解,本节带来的内容是OPEN SQL中DML语句的介绍,希望大家喜欢!


🤟每日一言: 永远年轻,永远热泪盈眶!

目录

  • 前言
  • DELETE语句介绍
    •  删除单条数据
      •   使用结构体变量删除单条数据
      •   使用WHERE子句删除单条数据
    •  删除多条数据
      •   使用WHERE子句删除多条数据
  • MODIFY语句介绍
    •  操作单条数据
      •   使用结构体变量操作单条数据
      •   使用内表操作单条数据
    •  操作多条数据
      •   使用内表操作单条数据
  • 写在最后的话


前言

在这里插入图片描述

  各位小伙伴们大家好呀!今天继续SAP ABAP系列文章的讲解,本节继续讲解OPEN SQL中的DML语句,本节内容涉及到DELETE语句和MODIFY语句,希望大家喜欢!


DELETE语句介绍

在这里插入图片描述

  ABAP DELETE语句用于操作删除数据库表中的数据。

PS:DELETE语句不支持使用内表来进行数据的删除!

 删除单条数据


  以下是删除单条数据的一般语法样式:

DELETE FROM  WHERE .
DELETE  FROM .

参数介绍:

  • 是要删除数据的数据库表的名称。
  • :存放待删除数据的结构体变量(工作区)。
  • :WHERE字句限定条件

  使用结构体变量删除单条数据

  下面给出一段以SFLIGHT数据库表为基准的示例代码,对ABAP OPEN SQL中通过结构体变量DELETE删除单条数据进行详细的讲解,仅供参考:

DATA:gs_sflight TYPE sflight.gs_sflight-carrid = 'AC'.
gs_sflight-connid = 0820.
gs_sflight-price = 1600.DELETE sflight FROM gs_sflight.

在这里插入图片描述

在这里插入图片描述

  这段代码中首先参照数据库表sflight定义了一个结构体变量,并且对结构体中的carridconnid以及price字段赋值,最后使用DELETE语句在数据库表中找寻到与该结构体变量中数据相对应的数据条目对其进行删除。

PS:删除单条数据一般通过结构体变量赋值来删除,也可以使用只有一行数据的内表来删除。

  使用WHERE子句删除单条数据

  下面给出一段以SFLIGHT数据库表为基准的示例代码,对ABAP OPEN SQL中通过WHERE子句DELETE删除单条数据进行详细的讲解,WHERE可以通过设置多种条件来删除特定的数据条目:

DELETE FROM sflight
WHERE   carrid = 'AC'AND   connid = 0820AND   price = 1600.

在这里插入图片描述
在这里插入图片描述

PS:上面介绍了两种可以实现删除单条数据的DELETE语句,它们都可以实现相同的效果!下面介绍删除多条数据的语句。

 删除多条数据

PS:删除多条数据不再支持使用结构体变量来进行删除,可以使用WHERE子句来操作数据库表数据。


  以下是删除多条数据的一般语法样式:

DELETE FROM  WHERE .

参数介绍:

  • 是要删除数据的数据库表的名称。
  • :WHERE字句限定条件

  使用WHERE子句删除多条数据

  下面给出一段以SFLIGHT数据库表为基准的示例代码,对ABAP OPEN SQL中通过WHERE子句MODIFY操作单条数据进行详细的讲解,仅供参考:

DELETE  FROM SFLIGHT WHERE PRICE = 1600 OR PRICE = 2100.

在这里插入图片描述
在这里插入图片描述

PS:这里的连接关键词需要用OR而不是AND! ! !


MODIFY语句介绍

在这里插入图片描述
  ABAP MODIFY语句用于操作增加或者修改数据库表中的数据。

PS:如果数据库表中不存在该条数据会增加条目,如果数据库表中存在该条数据会修改条目!

 操作单条数据


  以下是操作单条数据的一般语法样式:

MODIFY  FROM .
MODIFY  FROM TABLE .

参数介绍:

  • 是要操作数据的数据库表的名称。
  • :存放待操作数据的结构体变量(工作区)。
  • :存放待操作数据的内表。

  使用结构体变量操作单条数据

  下面给出一段以SFLIGHT数据库表为基准的示例代码,对ABAP OPEN SQL中通过结构体变量MODIFY操作单条数据进行详细的讲解,仅供参考:

* 更新旧条目
DATA:gs_sflight TYPE sflight.gs_sflight-carrid = 'AC'.
gs_sflight-connid = 0820.
gs_sflight-fldate = '20020218'.
gs_sflight-price = 2500.
MODIFY sflight FROM gs_sflight.* 插入新条目
gs_sflight-carrid = 'AC'.
gs_sflight-connid = 0820.
gs_sflight-fldate = '20230312'.
gs_sflight-price = 2500.
MODIFY sflight FROM gs_sflight.

在这里插入图片描述

在这里插入图片描述

PS:可以看到,修改了一个旧条目,并且新增了一个新条目,都是使用MODIFY语句完成的效果。

  使用内表操作单条数据

  下面给出一段以SFLIGHT数据库表为基准的示例代码,对ABAP OPEN SQL中通过内表MODIFY操作单条数据进行详细的讲解,仅供参考:

* 更新旧条目
DATA:gs_sflight TYPE sflight,gt_sflight TYPE TABLE OF sflight.gs_sflight-carrid = 'AC'.
gs_sflight-connid = 0820.
gs_sflight-fldate = '20020218'.
gs_sflight-price = 2500.
APPEND gs_sflight TO gt_sflight.
MODIFY sflight FROM TABLE gt_sflight.* 插入新条目
gs_sflight-carrid = 'AC'.
gs_sflight-connid = 0820.
gs_sflight-fldate = '20230312'.
gs_sflight-price = 2500.
APPEND gs_sflight TO gt_sflight.
MODIFY sflight FROM TABLE gt_sflight.

在这里插入图片描述

在这里插入图片描述

PS:通过使用一条数据的内表来操作数据也可以达到与结构体变量相同的效果。

 操作多条数据

MODIFY语句操作多条数据只能使用内表进行操作,不支持WHERE子句。


  以下是操作单条数据的一般语法样式:

MODIFY  FROM TABLE .

参数介绍:

  • 是要操作数据的数据库表的名称。
  • :存放待操作数据的内表。

  使用内表操作单条数据

  下面给出一段以SFLIGHT数据库表为基准的示例代码,对ABAP OPEN SQL中通过内表MODIFY操作多条数据进行详细的讲解,仅供参考:

* 更新旧条目
DATA:gs_sflight TYPE sflight,gt_sflight TYPE TABLE OF sflight.gs_sflight-carrid = 'AC'.
gs_sflight-connid = 0820.
gs_sflight-fldate = '20020218'.
gs_sflight-price = 2500.
APPEND gs_sflight TO gt_sflight.* 插入新条目
gs_sflight-carrid = 'AC'.
gs_sflight-connid = 0820.
gs_sflight-fldate = '20230312'.
gs_sflight-price = 2500.
APPEND gs_sflight TO gt_sflight.
MODIFY sflight FROM TABLE gt_sflight.

在这里插入图片描述
在这里插入图片描述

  这段代码和上方使用内表MODIFY单条数据并没有太大的区别,只是删剪去了前面第一条的MODIFY语句,先向内表中插入了两条数据然后一起对数据库表进行操作。而上一段代码中是分别两次使用只有一行的内表对数据库表进行操作,它们实现的效果是一样的!


写在最后的话

  本文花费大量时间介绍了OPEN SQL中的DELETE语句和MODIFY语句的详细语法,希望能帮助到各位小伙伴,码文不易,还望各位大佬们多多支持哦,你们的支持是我最大的动力!

在这里插入图片描述

✨原创不易,还希望各位大佬支持一下\textcolor{blue}{原创不易,还希望各位大佬支持一下}原创不易,还希望各位大佬支持一下

👍 点赞,你的认可是我创作的动力!\textcolor{9c81c1}{点赞,你的认可是我创作的动力!}点赞,你的认可是我创作的动力!

⭐️ 收藏,你的青睐是我努力的方向!\textcolor{ed7976}{收藏,你的青睐是我努力的方向!}收藏,你的青睐是我努力的方向!

✏️ 评论,你的意见是我进步的财富!\textcolor{98c091}{评论,你的意见是我进步的财富!}评论,你的意见是我进步的财富!

相关内容

热门资讯

疯抢43轮!溢价33.9%!刚... 就在刚刚,江宁两幅低密地块成功出让!其中,三山G50地块热度非常高,该地块是三山板块近10年来首次推...
57岁湖北前首富骤然身亡,家居... wumiancaijing.com / 几个月前才喊着“既没有退休打算,更没想过逃避责任”的汪林朋...
布米普特拉北京投资基金管理有限... 当地时间七月二十九日,美国液化天然气(LNG)出口领域的新锐巨头Venture Global宣布成功...
国泰A500ETF半年蒸发百亿... 2025年中,公募总规模突破34万亿元,同比增加3万亿,其中指数基金的规模净增了2.17万亿元,是主...
原创 美... 前言 近日,美国财政部长贝森特在瑞典斯德哥尔摩的美中贸易谈判中公开透露。 美国国会正在审议一项针对...
年入250亿,波司登让中产又爱... 文 | 本原财经 中产的心头好,“羽绒服之王”波司登交卷了:2025财年,营收首次达到259.02...
创业板指跌逾2%!下跌个股近4... 【大河财立方消息】7月30日午后,指数走弱,创业板指下挫跌逾2.00%,沪指跌0.16%,深成指跌1...
纺织行业上市公司董秘PK:太平... 来源:新浪证券 数据显示,截止7月29日,A股市场共有5817家上市公司。董秘作为连接投资者与上市公...
文远知行Robotaxi获沙特... 本报讯 (记者袁传玺)7月28日,广州文远知行科技有限公司(以下简称“文远知行”,Nasdaq:WR...
新三板创新层公司九州量子大宗交... 每经讯,2025年7月30日,新三板创新层公司九州量子(837638,收盘价:1.64元)发生一笔大...
美国将对欧盟葡萄酒征收15%关... 经过紧张的谈判和不断升级的猜测,美国最终确认对所有进入美国市场的欧盟商品(包括葡萄酒、烈酒和利口酒)...
阿维塔陈卓:拟明年下半年推出与... 凤凰网科技讯 7月30日,阿维塔科技总裁陈卓在中国长安汽车集团有限公司正式成立后首场媒体沟通会上透露...
累计融资5亿! 广州跑出超级独... 对话 | 铅笔道CEO 王方 撰稿 | 铅笔道编辑 赵松格 外卖赛道有美团,生物医药界也有“美团”?...
美国股市今夏是否会过热?专家建... 财联社7月30日讯(编辑 黄君芝)对金融市场来说,今年夏天是一个复杂的时期。尽管市场一直在猜测未来会...
2025“数通链谷”杯上海市区... 7月30日,2025“数通链谷”杯上海市区块链产业应用职工劳动和技能竞赛在上海市静安区市北高新园区数...
李想回忆被赶出公司:站在对方的... 近日,李想在与鲁豫的对话中,回忆人生低谷:2008年,自己曾被创业伙伴联合逼宫,汽车之家面临严重的财...
中证香港300银行指数报118... 金融界7月30日消息,A股三大指数收盘涨跌不一,中证香港300银行指数 (H300银行,H30324...
凯德北京投资基金管理有限公司:... 7月15日,A股上演惊险过山车行情。沪指早盘冲高至3278点后快速回落,最终微涨0.17%报3241...
美财政部长称中国如继续购买俄罗... 7月30日,外交部发言人郭嘉昆主持例行记者会。有记者问:美国财政部长表示,如果中国继续购买俄罗斯石油...