查询abap 程式应用到系统表table
*&---------------------------------------------------------------------*
*& Report ZMM_TEXT
*&---------------------------------------------------------------------*
*&
*&---------------------------------------------------------------------*
REPORT ZMMR_TEXT4 NO STANDARD PAGE HEADING
MESSAGE-ID LINE-SIZE LINE-COUNT . TABLES:tstc,marc,mara,d010tab. DATA:BEGIN OF alv_data occurs ,
master LIKE d010tab-master,"程式名称
tcode LIKE tstc-tcode," tcode
tabname LIKE d010tab-tabname," 表格名称
structure(),"通透表
data(),"是否存在数据
END OF alv_data. DATA:BEGIN OF get_table occurs ,
tabname TYPE string,"表名
tabclass LIKE dd02vv-tabclass,"表格类型
END OF get_table. DATA: gs_layout TYPE slis_layout_alv,
gt_fieldcat TYPE slis_t_fieldcat_alv ,"with header line.
wa_fieldcat TYPE slis_fieldcat_alv.
************************************************************************
* Includes Module
************************************************************************ ************************************************************************
* Selection Screen
************************************************************************
SELECTION-SCREEN BEGIN OF BLOCK b1 WITH FRAME TITLE TEXT-b01.
PARAMETERS:p_master LIKE d010tab-master.
* p_code LIKE tstc-tcode ,
* p_table LIKE d010tab-tabname .
SELECTION-SCREEN END OF BLOCK b1. ************************************************************************
* Initialization
************************************************************************
INITIALIZATION. ************************************************************************
* At Selection Screen
************************************************************************
AT SELECTION-SCREEN. ************************************************************************
* At Selection Screen Output
************************************************************************
AT SELECTION-SCREEN OUTPUT. ************************************************************************
* Report Format
************************************************************************
TOP-OF-PAGE. END-OF-PAGE.
************************************************************************
* Main Process
************************************************************************
START-OF-SELECTION.
PERFORM get_data.
PERFORM get_col.
PERFORM alv_show.
END-OF-SELECTION. FORM get_data.
DATA: l_index LIKE sy-tabix,
l_num TYPE i.
gs_layout-colwidth_optimize = 'X'. *--------> remark 代码不能 inner join 未找到相应的原因 拆分以下sql如下
* SELECT tcode FROM tstc
** inner JOIN d010tab ON d010tab~master = tstc~pgmna "程式名称
* INTO CORRESPONDING FIELDS OF TABLE alv_data
* WHERE "d010tab~master EQ p_master AND
** tstc~pgmna EQ p_master
** PGMNA EQ p_master AND
* tcode EQ p_code.
** AND tcode EQ p_code
** AND tabname EQ p_table.
*--------> end remark SELECT * FROM d010tab
INNER JOIN tstc ON tstc~pgmna EQ d010tab~master "程式名称
INTO CORRESPONDING FIELDS OF TABLE alv_data
WHERE master EQ p_master. IF sy-subrc <> .
SELECT * FROM d010tab
INTO CORRESPONDING FIELDS OF TABLE alv_data
WHERE master EQ p_master.
ENDIF. SORT alv_data by tabname.
DELETE ADJACENT DUPLICATES FROM alv_data COMPARING tabname.
LOOP AT alv_data.
l_index = sy-tabix. CLEAR:get_table. SELECT SINGLE dd02vv~tabname
dd02vv~tabclass
FROM dd02vv
INNER JOIN dd02l ON dd02l~tabname EQ dd02vv~tabname
* INNER JOIN dd03l ON dd03l~tabname EQ dd02vv~tabname
INTO get_table
WHERE "dd02vv~tabclass IN ('TRANSP','CLUSTER','POOL') AND "透明表
dd02vv~contflag NE 'L' AND " 存储时资料的表格,空传送
dd02vv~as4local NOT IN ( 'N','T' ) AND " 未启用,临时版本
dd02vv~tabname EQ alv_data-tabname AND
is_gtt NE 'X' ." X全局临时表 N 没有全局临时表 IF get_table-tabclass EQ 'TRANSP' OR
get_table-tabclass EQ 'CLUSTER' OR
get_table-tabclass EQ 'POOL' .
alv_data-structure = 'Y'. " 为通透表
CLEAR:l_num.
SELECT COUNT(*) INTO l_num
UP TO ROWS
FROM (get_table-tabname).
IF sy-subrc = .
alv_data-data = 'Y'."存在数据
ELSE.
alv_data-data = 'N'."没有数据
ENDIF.
ELSEIF get_table-tabclass IS NOT INITIAL.
alv_data-structure = 'N'. "结构
alv_data-data = 'N'. "没有数据
ELSE.
DELETE alv_data INDEX l_index.
CONTINUE.
ENDIF.
MODIFY alv_data INDEX l_index.
ENDLOOP. SORT alv_data by structure DESCENDING data DESCENDING.
ENDFORM.
FORM GET_COL.
DATA: l_repid TYPE sy-repid,
l_inclname TYPE trdir-name,
l_idx LIKE sy-tabix. CLEAR: gt_fieldcat[], wa_fieldcat. l_repid = l_inclname = sy-cprog. CALL FUNCTION 'REUSE_ALV_FIELDCATALOG_MERGE'
EXPORTING
I_PROGRAM_NAME = L_REPID
I_INTERNAL_TABNAME = 'ALV_DATA'
I_INCLNAME = L_INCLNAME
CHANGING
CT_FIELDCAT = GT_FIELDCAT
EXCEPTIONS
INCONSISTENT_INTERFACE =
PROGRAM_ERROR =
OTHERS = . LOOP AT gt_fieldcat INTO wa_fieldcat.
l_idx = sy-tabix.
CASE wa_fieldcat-fieldname.
WHEN 'STRUCTURE'.
wa_fieldcat-seltext_s = wa_fieldcat-seltext_m =
wa_fieldcat-seltext_l = '是否为通透表'.
wa_fieldcat-ddictxt = 'S'.
WHEN 'DATA'.
wa_fieldcat-seltext_s = wa_fieldcat-seltext_m =
wa_fieldcat-seltext_l = '是否有数据'.
wa_fieldcat-ddictxt = 'S'.
* WHEN 'LIST_NUM'.
* wa_fieldcat-no_out = 'X'. " NO_OUT 不显示
ENDCASE.
* CLEAR wa_fieldcat-key.
MODIFY gt_fieldcat FROM wa_fieldcat INDEX l_idx.
ENDLOOP.
ENDFORM. FORM ALV_SHOW. DATA: LS_LAYOUT TYPE SLIS_LAYOUT_ALV.
CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY'
EXPORTING
I_CALLBACK_PROGRAM = SY-REPID
IS_LAYOUT = GS_LAYOUT
IT_FIELDCAT = GT_FIELDCAT[]
I_SAVE = 'A'
TABLES
T_OUTTAB = ALV_DATA
EXCEPTIONS
PROGRAM_ERROR =
OTHERS = .
ENDFORM.
直接输入程式名称执行
执行结果如下,有通透表和结构,透明表有检查是否存在数据
如有bug请告知作者.或有更好的方法也请分享给广大网友.废话不多说,赶快下载试试吧!
查询abap 程式应用到系统表table的更多相关文章
- DB2 存储过程创建、系统表
前段时间做了数据表拆分,进行数据迁移,用到一些SQL命令,语句记录下来 db2look是DB2用于生成数据库DDL语句的一个工具: 命令:db2look -d DBname -a -e -p -i u ...
- oracle系统表查询
oracle查询用户下的所有表 select * from all_tab_comments -- 查询所有用户的表,视图等select * from user_tab_comments -- 查询本 ...
- oracle 常用的系统表查询
(转自:http://blog.csdn.net/marshalchen/article/details/6552103) select * from user_tab_cols where colu ...
- 002_系统表查询(sysdatabases等)
002_系统表查询(sysdatabases等) --1.获取所有数据库名: SELECT Name FROM Master..SysDatabases ORDER BY Name --2.获取所有表 ...
- oracle系统表的查询
oracle查询用户下的所有表 select * from all_tab_comments -- 查询所有用户的表,视图等select * from user_tab_comments -- 查 ...
- mysql中【update/Delete】update中无法用基于被更新表的子查询,You can't specify target table 'test1' for update in FROM clause.
关键词:mysql update,mysql delete update中无法用基于被更新表的子查询,You can't specify target table 'test1' for update ...
- SQL表关联赋值、系统表、表数据删除
1. 表与表的关联赋值(用于表与表之间有关联字段,数据互传) 双表关联赋值 UPDATE #B SET #B.D=#A.B from #B inner join #A on #B.C=#A.A 多表关 ...
- SQLSERVER系统视图,系统表,sys.sql_modules视图
SQLServer中提供了相当丰富的系统视图,能够从宏观到微观,从静态到动态反应数据库对象的存储结果.系统性能.系统等待事件等等.同时 也保留了与早期版本兼容性的视图,主要差别在于SQLServer2 ...
- 通过 Informix 系统表监控和优化数据库
Informix 数据库系统字典表简介 Informix 数据库服务器运行时的状态信息是数据库管理员 DBA 进行系统监控和优化的必需信息来源.Informix 的状态信息在内部以 2 种方式存在,如 ...
随机推荐
- 【数论】[涨姿势:同余]P2312解方程
题目描述 已知多项式方程:\(a_0 + a_1x + a_2x^2+...+a_nx^n = 0\) 求这个方程在[1,m]内的整数解 \(1\leq n\leq100,|a_i|\leq 10^{ ...
- 使用VS2017遇到的一些小问题
一.去掉预编译头 使用VS2017的时候,发现总是会有"pch.h","stdafx.h"这类预编译头,去掉还会报错.作为新手的我,暂时用不到这些预编译头,于是 ...
- 【POJ3126】Prime Path
本题传送门 本题知识点:宽度优先搜索 题意很简单.要找一个质数变到另一个质数的最少步数,两个质数都是4位数,变的时候只能变其中一位,变了的数也仍是质数. 思路也很简单,对每一位数进行修改,如果修改后的 ...
- mark一下咕掉的题目
蒟蒻才普及组呀~ 大佬别D我 等集中补一下 CF980F:咋说捏,我觉得要联赛了做这题有点浪费时间,等想颓废了再来写写叭qwq 215E/279D/288E/331C3/431D/433E/750G/ ...
- 【Gamma】Scrum Meeting 1
目录 写在前面 gamma阶段角色更换 进度情况 任务进度表 Gamma阶段燃尽图 遇到的困难 照片 代码Commit记录 后端 前端 写在前面 例会时间:5.25 22:30-23:00 例会地点: ...
- 阿里云ecs centos yarn 安装
安装流程:https://yarn.bootcss.com/docs/install/#centos-stable
- bitcoinjs-lib 哈希交易之多笔交易合并。
转账的时候需要手动寻找每一笔未花费记录实在太费时. 比特币转账需要提取或合并所有未花费的交易中的比特币,才能实现交易. import * as bitcoin from 'bitcoinjs-lib' ...
- linux 实时监控网速脚本(转)
#!/bin/bash ethn=$ while true do RX_pre=$(cat /proc/net/dev | grep $ethn | sed 's/:/ /g' | awk '{pri ...
- easyui datagrid的行编辑器editor 如何实现新增时可修改,编辑时,不可修改
项目出现一个需求,要求用户界面的用户名,新增时,可自由输入,编辑时,不可修改 html页面 <table id="gridlist" data-bind="data ...
- Canal - 数据同步 - 阿里巴巴 MySQL binlog 增量订阅&消费组件
背景 早期,阿里巴巴 B2B 公司因为存在杭州和美国双机房部署,存在跨机房同步的业务需求 ,主要是基于trigger的方式获取增量变更.从 2010 年开始,公司开始逐步尝试数据库日志解析,获取增量变 ...