欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > PPT文档下载  

    ABAP开发培训入门.ppt

    • 资源ID:5573990       资源大小:424KB        全文页数:39页
    • 资源格式: PPT        下载积分:15金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要15金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    ABAP开发培训入门.ppt

    ABAP开发培训,什么是ABAP?,Advanced Business Application Programming高级商业应用程序设计。是SAP专有的开发语言,SAP的应用程序就是用ABAP语言开发的。,ABAP开发培训,ABAP的开发环境展示,ABAP开发培训,SAP的三层架构,表示层,应用层,数据库,ABAP开发培训,ABAP程序的种类,报表最常见的ABAP程序,展示数据,比如财务的三大报表。接口常见的接口如RFC/BAPI,iDoc,Webservice。这些都是以Function Module为基础的。增强对标准程序的增强(改动)。Dialog带交互的程序,SAP标准的事物码很多就是Dialog。,ABAP开发培训,ABAP的数据类型-基本数据类型,ABAP开发培训,用户定义的基本数据类型完全是以预定义的基本数据类型为基础的。使用TYPES语句定义自己的基本数据类型。TYPES:NUMBER TYPE I,LENGTH TYPE P DECIMALS 2,CODE(3)TYPE C.DATA:NO_FLIGHTS TYPE NUMBER,NO_PASSENGERS TYPE NUMBER,DISTANCE TYPE LENGTH,HEIGHT TYPE LENGTH,CITY_CODE TYPE CODE,COUNTRY_CODE TYPE CODE.数据类型可以在程序内部定义,但只能程序内部用;也可以在程序外部定义,这样全局都可以使用(事物码SE11)。,ABAP的数据类型-用户定义的基本数据类型,ABAP开发培训,两种结构化数据类型:结构(Structure)和 内表(Internal Table)。Structure:本质上讲是一个由多个字段组成的字段串,在程序中只能存储一条数据,如果不好抽象化,可以理解为Excel的一行。Internal Table:多行多列,可以理解为一个Structure纵向拉长。内表分3种,标准表,排序表,哈希表。结构和内表可以在程序内部定义,但只能程序内部用;也可以在程序外部定义,这样全局都可以使用(事物码SE11)。,ABAP的数据类型-结构化数据类型,ABAP开发培训,TYPES语句定义类型,DATA语句声明变量,如刚才用到的例子:TYPES:NUMBER TYPE I,LENGTH TYPE P DECIMALS 2,CODE(3)TYPE C.DATA:NO_FLIGHTS TYPE NUMBER,DISTANCE TYPE LENGTH,CITY_CODE TYPE CODE,CONSTANTS语句定义常量:CONSTANTS PI TYPE P DECIMALS 5 VALUE 3.14159.Hint:变量的命名参照开发规范。,ABAP程序的数据定义,ABAP开发培训,实际应用中,更多是直接用LIKE语句定义变量。DATA:ZMATNR LIKE MARA-MATNR,“物料号 ZMTART LIKE MARA-MTART.“物料类型或者DATA ZMATNR LIKE MARA-MATNR.DATA ZMTART LIKE MARA-MTART.两者的意义完全相同。DATA 变量名 LIKE 表-字段名(结构-字段名)DATA 变量名 LIKE 系统标准变量,ABAP程序的数据定义,ABAP开发培训,结构变量的定义:结构DATA:BEGIN OF GS_MARC,MATNR LIKE MARC-MATNR,WERKS LIKE MARC-WERKS,PSTAT LIKE MARC-PSTAT,BWTTY LIKE MARC-BWTTY,EKGRP LIKE MARC-EKGRP,END OF GS_MARC.这是一个5个字段的结构。G代表global,S代表Structure.结构也可以用SE11事物码在系统里定义,所有程序都可以使用,但命名必须以Z开头。Hint:结构变量的命名有规则,参见开发规范,ABAP程序的数据定义,ABAP开发培训,结构变量的定义:内表DATA:BEGIN OF GS_MARC,MATNR LIKE MARC-MATNR,WERKS LIKE MARC-WERKS,PSTAT LIKE MARC-PSTAT,BWTTY LIKE MARC-BWTTY,EKGRP LIKE MARC-EKGRP,END OF GS_MARC.DATA:GT_MARC LIKE STANDARD TABLE OF GS_MARC.GT_MARC就是一个标准内表。Hint:结构变量的命名有规则,参见开发规范,ABAP程序的数据定义,ABAP开发培训,结构变量的定义:结构和内表的多种定义方式鉴于SAP有大量标准的数据类型供参考,结构变量的命名有多种方式,例如:(MARC是系统标准表,MAAPV是标准结构,自建结构和自建表同例)结构:DATA GS_MARC LIKE MARC.内表:DATA GT_MARC LIKE TABLE OF MARC.结构:DATA GS_MAAPV LIKE MAAPV.内表:DATA GT_MAAPV LIKE TABLE OF MAAPV.结构:DATA GS_MARC2 LIKE LINE OF GT_MARC.内表:DATA GT_MAAPV2 LIKE TABLE OF GS_MAAPV.Hint:结构变量的命名有规则,参见开发规范,ABAP程序的数据定义,ABAP开发培训,结构变量的定义:内表和工作区。工作区是相对于内表而言的,在操作内表时,系统需要先把数据从内表取出来存放到对应的工作区,再进行相关的操作。通常情况下,定义一个内表的同时需要定义一个工作区。工作区通过结构定义。DATA GS_MARC LIKE MARC.DATA GT_MARC LIKE TABLE OF MARC.结构GS_MARC就可以作为内表GT_MARC的工作区。其他定义方式同此例。,ABAP程序的数据定义,ABAP开发培训,结构变量的定义:表头。DATA GT_MARC LIKE MARC OCCURS 0 WITH HEADER LINE.此语句会声明一个带有同名表头的内表,表头可作为工作区。这种命名方式会节省一些代码量,但不推荐使用,容易混乱。还是推荐使用一个内表+一个工作区的方式。有些比较旧的程序用的是这种带表头的内表,在这些程序里,以GT_MARC为例:GT_MARC表示工作区,GT_MARC-MATNR表示字段,GT_MARC表示整个内表。,ABAP程序的数据定义,ABAP开发培训,赋值:DATA VAR1(3)TYPE C VALUE abc.DATA VAR2(3)TYPE C.MOVE VAR1 TO VAR2.VAR2=VAR1.VAR2=abc.以上3条语句意义返回结果相同。赋值时注意数据格式,要求数据格式相同,或者两边存在转换规则,否则会报错。,基本ABAP语句,ABAP开发培训,运算:二元操作符包括:+:加法-:减法*:乘法/:除法*:乘方 DIV:整除忽略余数 MOD:取余数 需要注意,圆括号和操作符都是关键字,需要跟操作数之间至少用一个空格分开。(1+2)*3 应该写成(1+2)*3,基本ABAP语句,ABAP开发培训,条件:,基本ABAP语句,ABAP开发培训,循环:ABAP的循环分四种:DO.WHILE.ENDDO.ENDWHILE.LOOP SELECT.ENDLOOP.ENDSELECT.,基本ABAP语句,ABAP开发培训,循环:DOENDDO.DO和ENDDO之间的语句块会无限运行,直到遇到条件控制的跳出循环语句如EXIT等。在DO语句中还可以指定最多运行的次数,否则的话,将会出现无限循环无限循环。WHILEENDWHILE.在WHILE和ENDWHILE之间的语句块会一直执行,直到不再满足WHILE后面所指定的条件。WHILE循环用的不多。,基本ABAP语句,ABAP开发培训,循环:LOOPENDLOOP.循环读取内表的数据到工作区,供程序处理。实际应用最多的循环语句。一般情况下ABAP推荐把数据从数据库(硬盘)读到内表(内存),几乎有程序就有内表,有内表就有LOOP循环。SELECTENDSELECT.循环读数据库。影响效率,不建议使用,建议用FOR ALL ENTRIES IN语句一次性把数据读入内表。,基本ABAP语句,ABAP开发培训,消息:MESSAGE 语句向程序的用户发送对话消息,使用MESSAGE 语句必须指定三位数的消息号和消息类。MESSAGE E001(ZFI001)。事物码SE91维护消息类和消息。也可以在程序里写硬消息:MESSAGE 程序运行错误 TYPE E.但不推荐使用这种不规范的方式。,基本ABAP语句,ABAP开发培训,操作结构和内表:结构访问结构里的字段。GS_MARC-MATNR.结构里最常用的语句是MOVE-CORRESPONDING 语句。把一个结构的内容同时全部拷贝到另一个结构中。只有源结构和目标结构中有相同名称的组件才会拷贝,而目标结构中名称无法对应的组件保持不变。需要注意,如果两个结构中同名的组件有不同定义的话,拷贝时可能会出错。,基本ABAP语句,ABAP开发培训,操作结构和内表:内表访问单条记录 一般来说,需要一个与内表行结构相同相同的工作区来处理单条记录。APPEND:往内表的最后追加一条记录,只能用于标准表。INSERT:向内表插入一条记录,在标准表里跟 APPEND 的效果一样,在排序表里就插入到键指定的位置,在哈希表里则根据哈希运算法则插入到指定位置。READ TABLE:把表的指定行拷贝到结构中。MODIFY:使用结构的内容重写表的指定行。DELETE:删除表的指定行。COLLECT:把结构中的内容累加到内表具有相同键的行上,这时,只有非键字段才执行累加,并且只有非键字段都是数值的时候才能执行这个语句。一般内表里多个字段需要同时汇总时会用到COLLECT语句,比如财务的一些报表。,基本ABAP语句,ABAP开发培训,操作结构和内表:内表访问多条记录(结果集)处理结果集合 LOOP ENDLOOP:LOOP 语句一条一条的读出内表的数据行,写入 INTO 字句指定的结构中,结构的内容可用于输出,或者修改后写回内表。DELETE:删除满足条件的所有行。INSERT:把一个内表中的多行拷贝到另一个内表中。APPEND:把一个内表中的多行追加到另一个标准表中。想修改内表的某一行只能先把那行读到工作区,修改工作区后再写回内表,而不能以数组的方法访问到内表的指定一行,这是跟其他语言很不一样的地方。,基本ABAP语句,ABAP开发培训,操作结构和内表:内表使用索引读表(标准表和排序表)LOOP 中用 FROM-TO 子句可以读指定索引段的记录。READ 中用 INDEX 子句可以读指定索引的一条记录。使用条件读表 LOOP 中用 WHERE 子句可以读满足一定条件的记录。READ 中用 With KEY 子句可以读满足主键条件的记录。内表排序 标准表和排序表可以使用 SORT 语句对指定字段进行排序,如果没有指定升序或者降序就默认使用升序。,基本ABAP语句,ABAP开发培训,操作结构和内表:内表 REFRESH:清除整个内表的内容,释放部分内存,保留一些以备后续操作。CLEAR:对于没有表头的内表,跟 REFRESH 一样,清除内表的内容。对于有表头的内表,则只初始化表头。FREE:清除整个内表的内容,释放所有内存。在程序里,当内表以后不再使用的时候可以使用 FREE,这样能尽量多释放一些不用的内存。,基本ABAP语句,ABAP开发培训,数据获取 SAP后台可以连接多种数据库,ORACLE,DB2,SQLSERVER,SYBASE 每种数据库都有自己特点的SQL语法,不可能在开发时根据后台数据库的种类选择SQL语法,所以SAP用的是无关SQL标准的开放SQL,执行时由SAP负责转化成各种数据库能运行的SQL。,数据库操作,ABAP开发培训,数据获取使用开放SQL的 SELECT 语句来执行查询,它包含几个基本的组成部分。基本语法:SELECT FROM INTO WHERE SELECT 后面的块说明了需要读表的哪些字段。FROM 后面的块说明了需要读哪个数据源(数据源可以是表或者视图)。INTO 后面的块说明了读出的字段要放到哪个目标数据对象中(结构或内表)。WHERE 后面的块说明了读数据的基本条件,可选。SELECT MATNR WERKS PSTAT BWTTY EKGRP INTO TABLE GT_MARC FROM MARC WHERE WERKS=1000.,数据库操作,ABAP开发培训,数据获取获取单条数据 用 SELECT SINGLE 语句。如果目标结构的数据结构与查询字段的顺序不一致,或者使用*这样的通配符来指定查询字段,就需要CORRESPONDING FIELDS OF 子句,它会自动在源字段和目标字段之间找名称相同的项自动对应填入。这是常用的方式。SELECT SINGLE*INTO CORRESPODING FIELDS OF GS_MARC FROM MARC WHERE MATNR=000000001 AND WERKS=1000.SELECT SINGLE语句是在数据库表所有的KEY键都被用到的时候使用的,执行效率很高,可以用*。,数据库操作,ABAP开发培训,一个常见的报表的组成 选择屏幕。输入数据的筛选条件。数据定义。定义程序中用到的变量和常量,包括单个变量、结构、内表等。数据获取。一般是通过一定的条件从数据库读取出来,或者上传的TXT/EXCEL文档。数据处理。按照FUNCTION SPEC的要求,对获得的数据进行处理(增删改BAPI)。展示。输出处理好的数据。,报表程序介绍,ABAP开发培训,选择屏幕-屏幕元素定义PARAMETERS:P_WERKSLIKEMARD-WERKSOBLIGATORY.“工厂SELECT-OPTIONS:S_MATNRFORMARD-MATNR,“物料S_LGORTFORMARD-LGORT,“库存地点S_LFGJAFORMARD-LFGJA,“年度S_LFMONFORMARD-LFMON.“月度,报表程序介绍,ABAP开发培训,选择屏幕-屏幕效果,报表程序介绍,ABAP开发培训,选择屏幕-数据定义TABLES:MARD,MAKT.DATA:BEGINOFGS_MARD,MATNRLIKEMARD-MATNR,WERKSLIKEMARD-WERKS,LGORTLIKEMARD-LGORT,PSTATLIKEMARD-PSTAT,LFGJALIKEMARD-LFGJA,LFMONLIKEMARD-LFMON,LABSTLIKEMARD-LABST,MAKTXLIKEMAKT-MAKTX,ENDOFGS_MARD.DATAGT_MARDLIKETABLEOFGS_MARD.,报表程序介绍,ABAP开发培训,选择屏幕-屏幕输出相关数据定义TYPE-POOLS:SLIS.*ALV变量定义.DATA:WS_FIELDCATTYPESLIS_T_FIELDCAT_ALVWITHHEADERLINE,I_FIELDCAT1TYPESLIS_T_FIELDCAT_ALVWITHHEADERLINE.DATA:WS_FIELDGROUPS_TABTYPESLIS_T_SP_GROUP_ALV,WS_LAYOUTTYPESLIS_LAYOUT_ALV,WS_SORTFIELDS_TABTYPESLIS_T_SORTINFO_ALVWITHHEADERLINE,WS_EVENTSTYPESLIS_T_EVENT.DATA:V_REPIDLIKESY-REPID.,报表程序介绍,ABAP开发培训,数据获取和处理SELECTAMATNRAWERKSALGORTAPSTATALFGJAALFMONALABST BMAKTXINTOTABLEGT_MARDFROMMARDASAINNERJOINMAKTASBONAMATNR=BMATNRWHEREBSPRAS=1ANDAWERKS=P_WERKSANDAMATNRINS_MATNRANDALGORTINS_LGORTANDALFGJAINS_LFGJAANDALFMONINS_LFMON.DELETEGT_MARDWHEREMAKTXISINITIAL.,报表程序介绍,ABAP开发培训,输出-构建输出元素 WS_FIELDCAT-TABNAME=GT_MARD.WS_FIELDCAT-FIELDNAME=MATNR.“字段名WS_FIELDCAT-SELTEXT_L=物料.”字段文本WS_FIELDCAT-COL_POS=1.“输出位置WS_FIELDCAT-OUTPUTLEN=18.”输出长度WS_FIELDCAT-DATATYPE=CHAR.“字段类型APPENDWS_FIELDCAT.CLEARWS_FIELDCAT.相当于把内表的数据再附加一些展示时用的属性。,报表程序介绍,ABAP开发培训,输出-展示效果设置WS_LAYOUT-ZEBRA=X.WS_LAYOUT-COLWIDTH_OPTIMIZE=X.ALV的LAYOUT有几十个参数,这里只用了最常用的2个:斑马纹,自适应列宽。,报表程序介绍,ABAP开发培训,输出-FMCALLFUNCTIONREUSE_ALV_GRID_DISPLAY EXPORTINGI_CALLBACK_PROGRAM=V_REPIDIS_LAYOUT=WS_LAYOUTIT_FIELDCAT=WS_FIELDCAT*IT_SPECIAL_GROUPS=WS_FIELDGROUPS_TAB*IT_SORT=WS_SORTFIELDS_TAB*it_events=ws_events*IT_EVENTS=GT_EVENTCATI_DEFAULT=XI_SAVE=A*i_grid_title=title*I_CALLBACK_PF_STATUS_SET=PF_STATUS_SET*I_CALLBACK_USER_COMMAND=MYCOMMAND*I_CALLBACK_USER_COMMAND=USER_COMMANDTABLES T_OUTTAB=GT_MARDEXCEPTIONS PROGRAM_ERROR=1 OTHERS=2.,报表程序介绍,ABAP开发培训,事件驱动INITIALIZATION初始化,设定屏幕元素默认值AT SELECTION-SCREEN检查屏幕输入START-OF-SELECTION从数据库取数操作END-OF-SELECTION此事件中进行输出清单操作,报表程序介绍,

    注意事项

    本文(ABAP开发培训入门.ppt)为本站会员(牧羊曲112)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开