REPORT ZSTATFILE LINE-SIZE 164.
************************************************************************
* This is an example of how to dig out some interesting performance
* and statistical data from the STAT file.
* The program creates a rank list of users based upon their database
* update and read activity. The results are the accumulated database
* time and row number per user for the different categories:
* insert/delete/modify and sequential/direct read. The results can be
* sorted by any of these categories.
* There are a lot more interesting data in the STAT file that can
* be used to write similar programs.
************************************************************************
DATA: STATISTIC_VERSION_USED LIKE SAPWLPSTRC-VERSION.
DATA: SORT_FIELD(20).
* General input parameters: from/to, client, STAT file path
SELECTION-SCREEN BEGIN OF BLOCK B1 WITH FRAME TITLE T7.
SELECTION-SCREEN BEGIN OF LINE.
SELECTION-SCREEN COMMENT 1(30) F1.
SELECTION-SCREEN POSITION 40.
PARAMETERS: FDAT LIKE SY-DATUM,
FTIM LIKE SY-UZEIT.
SELECTION-SCREEN END OF LINE.
SELECTION-SCREEN BEGIN OF LINE.
SELECTION-SCREEN COMMENT 1(30) F2.
SELECTION-SCREEN POSITION 40.
PARAMETERS: TDAT LIKE SY-DATUM,
TTIM LIKE SY-UZEIT.
SELECTION-SCREEN END OF LINE.
SELECTION-SCREEN BEGIN OF LINE.
SELECTION-SCREEN COMMENT 1(30) F4.
SELECTION-SCREEN POSITION 40.
PARAMETERS: CLI LIKE SY-MANDT.
SELECTION-SCREEN END OF LINE.
*SELECTION-SCREEN BEGIN OF LINE.
*SELECTION-SCREEN COMMENT 1(35) F3.
*SELECTION-SCREEN POSITION 40.
*PARAMETERS: FILE(128) LOWER CASE.
*SELECTION-SCREEN END OF LINE.
SELECTION-SCREEN END OF BLOCK B1.
* Sort order input
SELECTION-SCREEN BEGIN OF BLOCK B2 WITH FRAME TITLE T5.
SELECTION-SCREEN BEGIN OF LINE.
SELECTION-SCREEN COMMENT 1(30) F5.
SELECTION-SCREEN POSITION 40.
PARAMETERS: ASC RADIOBUTTON GROUP ORD,
DESC RADIOBUTTON GROUP ORD.
SELECTION-SCREEN END OF LINE.
SELECTION-SCREEN END OF BLOCK B2.
* Sort criteria input
SELECTION-SCREEN BEGIN OF BLOCK B3 WITH FRAME TITLE T6.
SELECTION-SCREEN BEGIN OF LINE.
SELECTION-SCREEN COMMENT 1(30) T1.
SELECTION-SCREEN POSITION 62.
PARAMETERS: A1 RADIOBUTTON GROUP SORT.
SELECTION-SCREEN END OF LINE.
SELECTION-SCREEN BEGIN OF LINE.
SELECTION-SCREEN COMMENT 1(55) T2.
SELECTION-SCREEN POSITION 62.
PARAMETERS: A2 RADIOBUTTON GROUP SORT.
PARAMETERS: A3 RADIOBUTTON GROUP SORT.
SELECTION-SCREEN POSITION 67.
PARAMETERS: A4 RADIOBUTTON GROUP SORT.
PARAMETERS: A5 RADIOBUTTON GROUP SORT.
SELECTION-SCREEN END OF LINE.
SELECTION-SCREEN BEGIN OF LINE.
SELECTION-SCREEN COMMENT 1(55) T3.
SELECTION-SCREEN POSITION 62.
PARAMETERS: A6 RADIOBUTTON GROUP SORT.
PARAMETERS: A7 RADIOBUTTON GROUP SORT.
SELECTION-SCREEN POSITION 67.
PARAMETERS: A8 RADIOBUTTON GROUP SORT.
PARAMETERS: A9 RADIOBUTTON GROUP SORT.
SELECTION-SCREEN POSITION 72.
PARAMETERS: AA RADIOBUTTON GROUP SORT.
PARAMETERS: AB RADIOBUTTON GROUP SORT.
SELECTION-SCREEN END OF LINE.
SELECTION-SCREEN BEGIN OF LINE.
SELECTION-SCREEN COMMENT 1(50) T4.
SELECTION-SCREEN POSITION 62.
PARAMETERS: AC RADIOBUTTON GROUP SORT.
PARAMETERS: AD RADIOBUTTON GROUP SORT.
SELECTION-SCREEN POSITION 67.
PARAMETERS: AE RADIOBUTTON GROUP SORT.
PARAMETERS: AF RADIOBUTTON GROUP SORT.
SELECTION-SCREEN POSITION 72.
PARAMETERS: AG RADIOBUTTON GROUP SORT.
PARAMETERS: AH RADIOBUTTON GROUP SORT.
SELECTION-SCREEN END OF LINE.
SELECTION-SCREEN END OF BLOCK B3.
*Internal tables
DATA: BEGIN OF V1_NORMAL_RECORDS OCCURS 100.
INCLUDE STRUCTURE SAPWLSTATR.
DATA: END OF V1_NORMAL_RECORDS.
DATA: BEGIN OF V2_NORMAL_RECORDS OCCURS 100.
INCLUDE STRUCTURE SAPWLPFNRM.
DATA: END OF V2_NORMAL_RECORDS.
DATA: BEGIN OF SUM OCCURS 100,
ACCOUNT(32),
READSEQREC TYPE I,
READSEQTI TYPE I,
READDIRREC TYPE I,
READDIRTI TYPE I,
UPDREC TYPE I,
UPDTI TYPE I,
DELREC TYPE I,
DELTI TYPE I,
INSREC TYPE I,
INSTI TYPE I,
SUM_RD_ROW TYPE I,
SUM_RD_TIM TYPE I,
SUM_MOD_ROW TYPE I,
SUM_MOD_TIM TYPE I,
SUM_ALL_ROW TYPE I,
SUM_ALL_TIM TYPE I,
END OF SUM.
*Initialize the selection screen
INITIALIZATION.
T1 = 'User Name and Report Name'.
T2 = 'READ: Sequential(row/time) Direct(row/time)'.
T3 = 'Update(row/time) Delete(row/time) Insert(row/time)'.
T4 = 'SUM: Read(row/time) Modify(row/time) All(row/time)'.
T5 = 'Sort'.
T6 = 'By'.
T7 = 'Period, Client and STAT file'.
F1 = 'From: (date/time)'.
F2 = 'To: (date/time)'.
* F3 = 'STAT file path(only for old stat)'.
F4 = 'Client'.
F5 = 'Ascending/Descending'.
FDAT = SY-DATUM. FTIM = SY-UZEIT.
FDAT = FDAT - 1. TTIM = SY-UZEIT.
TDAT = SY-DATUM.
CLI = SY-MANDT.
* Write a page header
TOP-OF-PAGE.
WRITE: / 'User and Report ' COLOR 2,
34(15) 'Sequential read' COLOR 2,
50(15) 'Direct read' COLOR 2,
66(15) 'Update' COLOR 2,
82(15) 'Delete' COLOR 2,
98(15) 'Insert' COLOR 2,
114(15) 'Sum Read' COLOR 5,
130(15) 'Sum Modify' COLOR 5,
146(15) 'Sum All' COLOR 6.
WRITE: / 'name' COLOR 2,
34(6) 'rows' COLOR 2,
41(8) 'time(ms)' COLOR 2,
50(6) 'rows' COLOR 2,
57(8) 'time(ms)' COLOR 2,
66(6) 'rows' COLOR 2,
73(8) 'time(ms)' COLOR 2,
82(6) 'rows' COLOR 2,
89(8) 'time(ms)' COLOR 2,
98(6) 'rows' COLOR 2,
105(8) 'time(ms)' COLOR 2,
114(6) 'rows' COLOR 5,
121(8) 'time(ms)' COLOR 5,
130(6) 'rows' COLOR 5,
137(8) 'time(ms)' COLOR 5,
146(6) 'rows' COLOR 6,
153(8) 'time(ms)' COLOR 6.
* Main
START-OF-SELECTION.
* Figure out the sort field name
IF A1 = 'X'.
SORT_FIELD = 'ACCOUNT'.
ELSEIF A2 = 'X'.
SORT_FIELD = 'READSEQREC'.
ELSEIF A3 = 'X'.
SORT_FIELD = 'READSEQTI'.
ELSEIF A4 = 'X'.
SORT_FIELD = 'READDIRREC'.
ELSEIF A5 = 'X'.
SORT_FIELD = 'READDIRTI'.
ELSEIF A6 = 'X'.
SORT_FIELD = 'UPDREC'.
ELSEIF A7 = 'X'.
SORT_FIELD = 'UPDTI'.
ELSEIF A8 = 'X'.
SORT_FIELD = 'DELREC'.
ELSEIF A9 = 'X'.
SORT_FIELD = 'DELTI'.
ELSEIF AA = 'X'.
SORT_FIELD = 'INSREC'.
ELSEIF AB = 'X'.
SORT_FIELD = 'INSTI'.
ELSEIF AC = 'X'.
SORT_FIELD = 'SUM_RD_ROW'.
ELSEIF AD = 'X'.
SORT_FIELD = 'SUM_RD_TIM'.
ELSEIF AE = 'X'.
SORT_FIELD = 'SUM_MOD_ROW'.
ELSEIF AF = 'X'.
SORT_FIELD = 'SUM_MOD_TIM'.
ELSEIF AG = 'X'.
SORT_FIELD = 'SUM_ALL_ROW'.
ELSEIF AH = 'X'.
SORT_FIELD = 'SUM_ALL_TIM'.
ENDIF.
CALL FUNCTION 'SAPWL_STATREC_READ_FILE'
EXPORTING
READ_CLIENT = CLI
READ_END_DATE = TDAT
READ_END_TIME = TTIM
READ_START_DATE = FDAT
READ_START_TIME = FTIM
* STATISTIC_FILE = FILE
IMPORTING
STATISTIC_VERSION_USED = STATISTIC_VERSION_USED
TABLES
V1_NORMAL_RECORDS = V1_NORMAL_RECORDS
V2_NORMAL_RECORDS = V2_NORMAL_RECORDS.
LOOP AT V2_NORMAL_RECORDS.
V2_NORMAL_RECORDS-READSEQTI = V2_NORMAL_RECORDS-READSEQTI / 1000.
V2_NORMAL_RECORDS-READDIRTI = V2_NORMAL_RECORDS-READDIRTI / 1000.
V2_NORMAL_RECORDS-UPDTI = V2_NORMAL_RECORDS-UPDTI / 1000.
V2_NORMAL_RECORDS-DELTI = V2_NORMAL_RECORDS-DELTI / 1000.
V2_NORMAL_RECORDS-INSTI = V2_NORMAL_RECORDS-INSTI / 1000.
MODIFY V2_NORMAL_RECORDS.
ENDLOOP.
LOOP AT V1_NORMAL_RECORDS.
V1_NORMAL_RECORDS-READSEQTI = V1_NORMAL_RECORDS-READSEQTI / 1000.
V1_NORMAL_RECORDS-READDIRTI = V1_NORMAL_RECORDS-READDIRTI / 1000.
V1_NORMAL_RECORDS-UPDTI = V1_NORMAL_RECORDS-UPDTI / 1000.
V1_NORMAL_RECORDS-DELTI = V1_NORMAL_RECORDS-DELTI / 1000.
V1_NORMAL_RECORDS-INSTI = V1_NORMAL_RECORDS-INSTI / 1000.
MODIFY V1_NORMAL_RECORDS.
ENDLOOP.
LOOP AT V2_NORMAL_RECORDS.
MOVE-CORRESPONDING V2_NORMAL_RECORDS TO SUM.
CONCATENATE V2_NORMAL_RECORDS-ACCOUNT V2_NORMAL_RECORDS-CUA_PROG
INTO SUM-ACCOUNT SEPARATED BY SPACE.
COLLECT SUM.
ENDLOOP.
LOOP AT V1_NORMAL_RECORDS.
MOVE-CORRESPONDING V1_NORMAL_RECORDS TO SUM.
CONCATENATE V1_NORMAL_RECORDS-ACCOUNT V1_NORMAL_RECORDS-CUA_PROG
INTO SUM-ACCOUNT SEPARATED BY SPACE.
COLLECT SUM.
ENDLOOP.
LOOP AT SUM.
SUM-SUM_RD_ROW = SUM-READSEQREC + SUM-READDIRREC.
SUM-SUM_RD_TIM = SUM-READSEQTI + SUM-READDIRTI.
SUM-SUM_MOD_ROW = SUM-UPDREC + SUM-DELREC + SUM-INSREC.
SUM-SUM_MOD_TIM = SUM-UPDTI + SUM-DELTI + SUM-INSTI.
SUM-SUM_ALL_ROW = SUM-SUM_RD_ROW + SUM-SUM_MOD_ROW.
SUM-SUM_ALL_TIM = SUM-SUM_RD_TIM + SUM-SUM_MOD_TIM.
MODIFY SUM.
ENDLOOP.
IF ASC = 'X'.
SORT SUM BY (SORT_FIELD) ASCENDING.
ELSE.
SORT SUM BY (SORT_FIELD) DESCENDING.
ENDIF.
LOOP AT SUM.
WRITE: / SUM-ACCOUNT,
34(7) SUM-READSEQREC,
42(7) SUM-READSEQTI,
54(7) SUM-READDIRREC,
58(7) SUM-READDIRTI,
66(7) SUM-UPDREC,
74(7) SUM-UPDTI,
82(7) SUM-DELREC,
90(7) SUM-DELTI,
98(7) SUM-INSREC,
106(7) SUM-INSTI,
114(7) SUM-SUM_RD_ROW,
122(7) SUM-SUM_RD_TIM,
130(7) SUM-SUM_MOD_ROW,
138(7) SUM-SUM_MOD_TIM,
146(7) SUM-SUM_ALL_ROW,
154(7) SUM-SUM_ALL_TIM.
ENDLOOP.
*-------- END OF PROGRAM --------------------------------
Friday, November 23, 2007
ABAP retrieve statistical data from the STAT file
Subscribe to:
Post Comments (Atom)
Blog Archive
-
▼
2007
(952)
-
▼
November
(716)
- SAP Paper Documents
- SAP Repository
- SAP R/3 Implementation and Maintenance Tips
- ABAP/4 programming language overview
- The interactive eLearning system for ABAP™
- Helpful System Administration ABAPS
- free download abap programmin pdf book
- examples of real time objects in sap abap(1)
- examples of real time objects in sap abap
- work flow example2
- Workflow tips
- Miscellaneous sap abap faq
- BDC , LSMW, Conversions faq in abap
- Sap Scripts & Smart forms faqs in abap
- performance tuning in abap faqs
- Real Time BDC & LSMW faqs
- Real Time ABAP Internal Tables faqs
- Real Time ABAP Reports faqs
- Real Time questions ..in sap ABAP
- SAP ABAP FAQ (Technical)
- ABAP and Unicode
- ABAP and JavaScript
- ABAP Objects
- ABAP Database Access
- Running ABAP Programs
- ABAP User Dialogs
- The ABAP Programming Language
- Creating and Changing ABAP Programs
- Overview of the Components of Application Programs
- Introduction to ABAP
- ABAP Programming Documentation
- FREE DOWNLOAD ALE, EDI & IDOCS
- Conversion of IDOCs to XML.pdf
- FREE DOWNLOAD IDOC Interface Technology
- FREE DOWNLOAD EDI, IDOC Interface
- FREE DOWNLOAD IDOC BOOK
- FREE DOWNLOAD LSMW - Idoc Inbound Processing
- FREE DOWNLOAD SAP ABAP Idoc Interface
- FREE DOWNLOAD Java for SAP
- FREE DOWNLOAD Java for ABAP Programmers
- FREE DOWNLOAD Java and BAPI technology for EP
- free download Building Web Services with Java and ...
- free download Enable SAP with the power of Javascript
- FREE DOWNLOAD ABAP Training Simulator
- FREE DOWNLOAD SAP Accounting Training Simulators
- free download SAPScripts Made Easy
- CONDENSE
- CONSTANTS
- ABAP Quick Viewer
- sap abap XXL (EXtended Export of Lists)
- Some ABAP/4 Query header line variable
- Understanding SAP Query
- ABAP/4 Query
- ABAP/4 Query Hints and Tips
- SAP Website Links Exchange for ABAP, Basis or Cons...
- sap abap Program for Generate IDoc
- sap abap program for Reads an existing Idoc and di...
- List of ABAP Function modules
- sap abap FTP programming
- sap abap program for Issuing an Unix Command from ...
- sap abap program for RFC call to get Server List
- sap abap program for A SAP Pop-out Calculator
- sap ABAP program for Timers and Auto-refresh
- sap abap program for WS_EXECUTE to called External...
- sap abap programming Execute DOS Command from ABAP...
- To execute a dos command from ABAP
- sap abap program for Make your SAPGUI Disappear an...
- sap abap program for Using Function Modules F4_FIL...
- abp program for How to Restrict the Select Options
- sap abap program for Take Values from Selection-Sc...
- sap abap program for Change Text Into Password
- sap abap program for Function Module for Encryptio...
- sap abap program for FM VRM_SET_VALUE To List Box
- sap abap program for Value Request For Parameter
- sap abap program for Pop a Message to specific SAP...
- ABAP Pop-out box for user confirmation
- sap ABAP program for POP-UP Window
- sap abap program Sample XML Source Code For SAP
- sap abap XML file to word document through SAP
- sap abap program for How to Write Web Reports in SAP
- sap abap conversion Program to Test Line Selection...
- sap abap program for String Handling in ABAP - Rem...
- sap abap program for Split String into two parts a...
- sap abap conversion Program For Printing Prime Number
- sap abap program for How can I get Ascii value of ...
- sap abap program for Figure to Words for India but...
- sap abap conversion program for Print Number Value...
- sap abap conversion program for Insert a special T...
- sap abap program for String Handling in ABAP - Rem...
- sap abap program for Split String into two parts a...
- sap abap conversion Program For Printing Prime Number
- sap abap program for How can I get Ascii value of ...
- sap abap program for Figure to Words for India but...
- sap abap conversion program for Print Number Value...
- sap abap conversion program for Insert a special T...
- sap abap program for Convert SAP Spool List to HTML
- sap program for Convert Month to Word in ABAP
- ABAP function to convert Number to Words
- sap abap program for How to Create Tree Control
- sap abap A sample Tree Programming
- sap abap program for Use BDS to Store Files Like E...
- Creating Chart in ABAP
- sap abap real time object for GUI_* WS_* Function ...
- abap real time object for Reading attribute of a B...
- sap abap real time object program for Splash Scree...
- ABAP Real time object for To Use BADI - Business A...
- sap ABAP Object Oriented SpreadSheet with "Unlimit...
- What are ABAP Objects?
- sap abap program for Prevent program from having m...
- sap abap program for Get the windows registry valu...
- sap abap program for How to Open files from the pr...
- sap abap program for Download and Upload your ABAP...
- sap abap program for Download/Upload SAP Users Fav...
- sap abap program for Download in Background in Exc...
- sap abap program for Excel Upload Alternative - KC...
- sap abap program for Uploading multiple multitab E...
- sap abap program for Uploading data directly from ...
- sap abap program for Use SAP code to list how many...
- sap abap program for How to Create Pivot Table in ...
- sap abap program for Sending Mail When The Purchas...
- sap abap program for Make E-mail Sender of PO the ...
- How can you send a fax from within ABAP/4 programs?
- sap abap program for How to send a report to an ex...
- sap abap program for Sending External email throug...
- Sending mail with attachment report in Background
- sap abap program for Sending mail with attachment
- abap program for Date, Month and Popup Related Fun...
- sap abap program for Determine Last Day of the Pre...
-
▼
November
(716)




No comments:
Post a Comment