打开SAP 客户端工具

ABAP 中 创建包(SE80)

创建函数组

展开ABAP 工作台,双击ABAP Dictionary 字典:

选择第三个data type,输入数据结构名称ZSQL_CLAUSE_ELEMENTS,点击创建:

选中Structure结构,点击确定:

输入简称,增加一个数据元素TEXT,类型为SO_TEXT

同样的方法,我们创建Structure结构ZTABLEROWS,增加一条数据元素,名字任意如ZTABLEROWS,数据元素 CHAR2000

保存这两个structure,然后点击上方的结构树按钮,打开Structure所在包目录

展开Structure目录,就可以看到我们定义的那两个结构了,分别右击>Activate激活

FUNCTION HHDI_EXTRACT_TABLE_DATA.

*"----------------------------------------------------------------------

*"*"Local Interface:

*"  TABLES

*"      FIELDS STRUCTURE  ZSQL_CLAUSE_ELEMENTS

*"      FROMCLAUSE STRUCTURE  ZSQL_CLAUSE_ELEMENTS

*"      WHERECLAUSE STRUCTURE  ZSQL_CLAUSE_ELEMENTS

*"      DATA STRUCTURE  ZTABLEROWS

*"----------------------------------------------------------------------

*"----------------------------------------------------------------------

*" Copy selected fields from QUERY_TABLE to DATA_STRUCTURE

*"----------------------------------------------------------------------

TYPE-POOLS: abap.

DATA:

columnName TYPE SO_TEXT,

fieldDataDescrRef  TYPE REF TO abap_componentdescr,

numberFields TYPE i,

fieldDescr TYPE abap_componentdescr,

fieldname TYPE string,

fieldDescrTab TYPE abap_component_tab,

rowStructDescr TYPE REF TO cl_abap_structdescr,

rowReference TYPE REF TO data,

returnRowString TYPE string,

dataFieldString TYPE string,

dataline LIKE data,

fromClauseRow TYPE ZSQL_CLAUSE_ELEMENTS,

fromClauseString TYPE string,

whereClauseRow TYPE ZSQL_CLAUSE_ELEMENTS,

whereClauseString TYPE string,

fieldsRow TYPE ZSQL_CLAUSE_ELEMENTS.

FIELD-SYMBOLS:

<datarow> TYPE ANY,

<datafield> TYPE ANY.

* CREATE DataStructure with field names

* Datatypes are read from fieldnames of FIELDS input table

DESCRIBE TABLE FIELDS LINES numberFields.

LOOP AT FIELDS INTO fieldsRow.

fieldname = SY-TABIX.

* names need to be unique and must start with a char

CONCATENATE 'string' fieldname INTO fieldname.

CONDENSE fieldname.

fieldDescr-name = fieldname.

* for dictionary lookup we need to change columnnames from Open SQL

* to dictionary notation

columnName = fieldsRow-TEXT.

REPLACE FIRST OCCURRENCE OF SUBSTRING '~' IN columnName WITH '-' RESPECTING CASE.

fieldDescr-type ?= cl_abap_typedescr=>describe_by_name( columnName ).

APPEND fieldDescr TO fieldDescrTab.

ENDLOOP.

rowStructDescr = cl_abap_structdescr=>create( fieldDescrTab ).

* now we create the actual data structure in memory

create data rowReference type HANDLE rowStructDescr.

* finally we assign it to the Field-symbol used by the select statement

ASSIGN rowReference->* TO <datarow>.

* End Create DataStructure

* to simplify calls we concatenate from and whereclause into strings

* this way caller doesn't need to check word wrappings

fromClauseString = ''.

LOOP AT FROMCLAUSE INTO fromClauseRow.

CONCATENATE fromClauseString fromClauseRow-TEXT INTO fromClauseString.

ENDLOOP.

whereClauseString = ''.

LOOP AT WHERECLAUSE INTO whereClauseRow.

CONCATENATE whereClauseString whereClauseRow-TEXT INTO whereClauseString.

ENDLOOP.

* Now start actual select operation

SELECT (FIELDS) FROM (fromClauseString) INTO <datarow> WHERE (whereClauseString).

* we read all fields of the current row, cast it to string and

* concatenate it into a dataline with division chars.

CLEAR: returnRowString.

DO numberFields TIMES.

ASSIGN component sy-index of structure <datarow> to <datafield>.

dataFieldString = <datafield>.

CONCATENATE returnRowString '|' datafieldstring INTO returnRowString.

ENDDO.

dataline = returnRowString.

* finally dataline is added to the return table.

INSERT dataline INTO TABLE data.

ENDSELECT.

ENDFUNCTION.

函数

l  新建abap function

注意函数的名称一定为:HHDI_EXTRACT_TABLE_DATA

先把HHDI_EXTRACT_TABLE_DATA的源码贴进去

点击左边的table表格tab,新增4个表,FIELDS /FROMCLAUSE /WHERECLAUSE /DATA,类型都为LIKE,后面的结构类型按照文档源码,前三个输入ZSQL_CLAUSE_ELEMENTS,最后一个输入ZTABLEROW

like报参数过时的错误,回车再回车即可。

再次check

没有错误则表示function 可以了,注意还需要设置函数可以远程访问

最后再激活一下。

在HHDI中SAP数据连接配置:

数据抽取任务的配置:

SELECT语句参考:

select KNA1~NAME2,KNVV~KUNNR,KNA1~LAND1 from KNA1 INNER JOIN KNVV ON KNA1~KUNNR = KNVV~KUNNR where KNA1~NAME2 <>'' AND KNA1~LAND1 = 'US'

注意OPENSQL不支持SELECT *

簇表数据量太大会导致SAP报缓存溢出的错误,可用WHERE语句控制其数据范围,数据量过大时,可以再HHDI的作业流程中采用循环方式取数。

如何从SAP ECC中抽取簇表数据的更多相关文章

  1. MO拆分计划行程序中写入PRODUCTIONORDERS表数据出现重复导致报错(BUG)20180502

    错误提示:ORA-00001: 违反唯一约束条件 (ABPPMGR.C0248833319_6192)ORA-06512: 在 "STG.FP_MO_SPLIT", line 19 ...

  2. Oracle GoldenGate 支持 从SAP HANA database抽取或者复制数据到SAP HANA database 吗?

    Oracle GoldenGate 支持 从SAP  HANA database抽取或者复制数据到SAP HANA database 吗? 来源于: Does Oracle GoldenGate Su ...

  3. SAP HANA SLT 将Oracle表 数据同步到HANA数据库

    简单介绍SLT 同步数据的整个配置过程: 在SLT系统中创建与Oracle的链接 在HANA监控平台上,创建Configuration 创建表的同步作业 ——————————————BEGIN———— ...

  4. 定时器中实现数据库表数据移动的功能,Exception in thread "Timer-0" isExist java.lang.NullPointerException定时器中线程报错。

    package com.shawnway.trade.marketdata.constants; import java.sql.SQLException; import java.util.Cale ...

  5. 查看SqlAzure和SQLServer中的每个表数据行数

    SqlAzure中的方式: select t.name ,s.row_count from sys.tables t join sys.dm_db_partition_stats s ON t.obj ...

  6. oracle中字符串与表数据拼接的用法--“||”

    测试过程中,经常需要批量删除或者插入.修改一些表数据或结构,使用手工复制.粘贴其实很麻烦,所以这是我们就可以使用拼接成sql语句的方法来实现操作数据.下面先讲讲oracle中拼接符 || 的用法,如下 ...

  7. 如何从mysql备份中提取单张表数据

    1.先提取备份数据中的前50行出来,查看一下备份数据格式    head -50 bakdb.sql > head50.txt        类似下面的数据是我们所需要提取的:        / ...

  8. 在pycharm中批量插入表数据、分页原理、cookie和session介绍、django操作cookie

    昨日内容回顾 ajax发送json格式数据 ''' 1. urlencoded 2. form-data 3. json ''' 1. ajax $.ajax({ data: JSON.stringi ...

  9. 误删除SAP ECC中的profile文件

    环境:ECC6.0 EHP4  FOR ORACLE ON WINDWS X64下 今天在RZ10配置系统参数文件的时候,不小心错删除了instance profile文件,这下惨了,这是操作系统层级 ...

随机推荐

  1. Scratch GUI

    原文地址:https://github.com/LLK/scratch-gui/wiki/Getting-Started Getting Started   Bryce Taylor edited t ...

  2. win8 便签工具

    启动或显示 Sticky Notes : Win+R--->StikyNot.exe 备份Sticky Notes 保存位置 : %AppData%\Microsoft\Sticky Notes ...

  3. Android SDK 墙内更新方法

    1.访问地址:http://ping.chinaz.com/,在网站测速处输入g.cn执行查看分析,如下图所示 2.在分析列表中找到速度最快的IP复制进行设置SDK代理并设置端口为80,并勾选Forc ...

  4. Eclipse 连接真实机器调试

    一.手机开启调试模式 二.安装adb.exe 1.确信 \android-sdk-windows\tools\下有 adb.exe     AdbWinApi.dll     AdbWinUsbApi ...

  5. ZooKeeper学习之路 (八)ZooKeeper原理解析

    ZooKeeper中的各种角色 ZooKeeper与客户端 每个Server在工作过程中有三种状态: LOOKING:当前Server不知道leader是谁,正在搜寻 LEADING:当前Server ...

  6. Owin+ASP.NET Identity浅析系列(四)实现用户角色

    在今天,读书有时是件“麻烦”事.它需要你付出时间,付出精力,还要付出一份心境.--仅以<Owin+ASP.NET Identity浅析系列>来祭奠那逝去的…… 通过Owin+ASP.NET ...

  7. leetcode300. Longest Increasing Subsequence 最长递增子序列 、674. Longest Continuous Increasing Subsequence

    Longest Increasing Subsequence 最长递增子序列 子序列不是数组中连续的数. dp表达的意思是以i结尾的最长子序列,而不是前i个数字的最长子序列. 初始化是dp所有的都为1 ...

  8. const引用和constexpr

    1.const指针 eg: (1)  int const * p = nullptr; p = new int[10]; p[3] = 4; //error 我们发现第三行没法编译,这是因为第一行的c ...

  9. 算法——(4)哈希、hashmap、hashtable

    1. Hash 把任意长度的输入通过散列算法,变换成固定长度的输出,该输出就是散列值.拥有四个特性: 1. 拥有无限的输入域和固定大小的输出域 2. 如果输入值相同,返回值一样 3. 如果输入值不相同 ...

  10. 【luogu P2831 愤怒的小鸟】 题解

    题目链接:https://www.luogu.org/problemnew/show/P2831 写点做题总结:dp,搜索,重在设计状态,状态设的好,转移起来也方便. 对于一条抛物线,三点确定.(0, ...