如何读取并处理数据库表_第1页
如何读取并处理数据库表_第2页
如何读取并处理数据库表_第3页
如何读取并处理数据库表_第4页
如何读取并处理数据库表_第5页
已阅读5页,还剩76页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

28))。始终需要指定集团。数据通过主机变量在数据库表和ABAP/4程序之间传送。这些变量在ABAP/4程序中声明,在自身的SQL语句中,这些变量前面要有一个冒号(:)。可将差不多字段和结构化字段用作主机变量。假如SELECT语句的结果是表,那么,就使用PERFORMING<form>选项在闭循环中逐行读取数据。对于每一行,都将调用一次子程序<form>。在该子程序中,可通过将数据附加到内表以便对其作进一步的处理。有关自身的SQL的详细信息,参见EXECSQL的关键字文档。DATA:BEGINOFWA,

CLIENT(3),

ARG1(3),

ARG2(3),

ENDOFWA.DATAF3VALUE'1'.EXECSQLPERFORMINGLOOP_OUTPUT.

SELECTCLIENT,ARG1INTO:WAFROMTABLE_001WHEREARG2=:F3

ENDEXEC.FORMLOOP_OUTPUT.

WRITE:/WA-CLIENT,WA-ARG2.

ENDFORM.在该示例中,工作区WA和字符字段F3都在自身的SQLSELECT语句中用作主机变量。WA是目标区,所选数据将读入该目标区。F3用在WHERE条件中。在子程序LOOP_OUTPUT中,将读入WA中的数据写到屏幕上。setZ_018pagepage3030在ABAP/4程序的执行过程中锁定数据库对象xe"DEQUEUE"xe"ENQUEUE"xe"数据库表,锁定"在SAP系统中,应用程序必须锁定它们使用的对象。这是因为每个程序都由两个任务组成:_ 对话任务,在该任务中输入或更改数据_ 更新任务,在该任务中更改数据库对话任务将用户输入的数据传送给更新任务。然后更新任务读取立即修改的数据并相应地修改数据库。通常,对话任务和更新任务是异步操作的。这意味着对话任务并不等待更新任务依照用户的输入修改数据库,而是立即返回到和用户的对话中。因为对话任务和更新任务是异步操作的,因此必须锁定所有涉及的对象,直到已成功地更改了数据库。在ABAP/4程序的执行过程中,必须锁定程序中的所有对象。例如,可能必须锁定客户主记录行来修改相应的商业区数据。在该情况下,只要锁定是活动的,其它用户就不能修改该客户主记录行。其它用户的对话必须等到该应用程序(包括更新任务)结束。要完全锁定一个数据对象,请使用SAP锁定机制(ENQUEUE/DEQUEUE)。每个应用程序都提供了大量可用于锁定数据对象的功能模块。要获得一个可用于锁定或解锁的功能模块的列表,请选择“ABAP/4开发工作台”屏幕上的“功能库”。这将进入“ABAP/4功能库:初始屏幕””,在那个地点选择“有用程序->查找”。在后续“ABAP/4库信息系统:功能模块”屏幕中,在“功能模块”字段中输入*queue*,然后单击“执行”。此操作开始搜索名称中包含ENQUEUE或DEQUEUE的功能模块。另外,可直接搜索用于处理要锁定的数据库对象的功能模块。请在“功能模块”区域中输入该对象的名称(包括用于类属搜索的星号)。详细信息,参见文档系统服务(页Error!Notavalidlink.)。setZ_020pagepage3030检查ABAP/4程序用户的权限xe"AUTHORITY-CHECK"xe"权限检查"xe"数据库表,权限检查"与使用逻辑数据库读取数据不同,运行时在ABAP/4程序中使用SQL语句处理数据可不能触发权限检查(参见逻辑数据库的优点(页Error!Notavalidlink.))。因为开放式SQL和自身的SQL语句同意无限制地访问所有数据库表,因此这将带来问题。不是要为所有用户授予在ABAP/4程序中使用SQL语句访问所有数据的权限。然而,公布程序之后,所有具有该程序使用权限的用户都能启动它。因此,作为编写SQL报表程序的程序员有责任检查调用该程序的用户是否有权访问将在其中处理的数据。要在ABAP/4程序中检查用户权限,请使用AUTHORITY-CHECK语句,如下所示:语法AUTHORITY-CHECKOBJECT'<object>'

ID'<name1>'FIELD<F1>

ID'<name2>'FIELD<F2>

ID'<name10>'FIELD<F10>.<object>是立即检查的授权对象的名称。必须在ID后列出在<object>中定义的所有授权字段的名称(<name1>,<name2>)。必须在<F1>,<F2>中为立即检查的权限输入值以作为变量或字母。然后,该语句将为命名的对象搜索该用户的参数文件,以检查该用户是否有<f>中所有值的授权。然后SY-SUBRC将设置为0。可用DUMMY替换.FIELD<f>跃过字段的检查。必须检查系统字段SY-SUBRC中的内容来检查AUTHORITY-CHECK的结果并作出相应的动作。有关可能的返回代码值的列表和详细信息,请参考AUTHORITY-CHECK的关键字文档。关于常用授权的概念,参见文档用户、权限和系统安全性(页Error!Notavalidlink.)。假设存在权限对象F_SPFLI和字段ACTVT、NAME及CITY。SELECT*FROMSPFLI.

AUTHORITY-CHECKOBJECT'F_SPFLI'

ID'ACTVT'FIELD'02'

ID'NAME'FIELDSPFLI-CARRID

ID'CITY'DUMMY.

I

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论