At my current project I needed a way to create Semantic Partitioning Object (SPO) via BAdI to reduce the end-of-year work. After a little search via Google (you cannot find anything on the new SAP Community Page), I found these threads.
Both were not perfect, so I build a solution between them. I also put everything via control tables, so it would be easier for the users to manage them. So let's get started.
Create own data dictionary objects
The following domains have to be implemented:
- ZSPOPARTGROUP - SPO Partition Group
- ZSPOPATTERNID - SPO Partitioning Pattern
- ZSPOTLOGO - SPO Object Type for DTP
SPO Partition Group
data:image/s3,"s3://crabby-images/94796/9479669605f5a99e66ecc70bfbec816a363afe57" alt="Domain: ZSPOPARTGROUP"
SPO Partitioning Pattern
data:image/s3,"s3://crabby-images/e45b3/e45b3a49bfd9fc138f5bfeee445c3d2d373aa273" alt="Domain: ZSPOPATTERNID"
SPO Object Type for DTP
data:image/s3,"s3://crabby-images/5dab6/5dab6443df0e306564e8ce0cc4dd773df7e95162" alt="Domain: ZSPOTLOGO"
data:image/s3,"s3://crabby-images/f2be9/f2be9f920e70a0128ccfc143cc3568d926c34bb8" alt="Domain: ZSPOTLOGO Value Range"
After we created the domains, we have to create the following data elements:
- ZSPOPARTGROUP - SPO Partition Group
- ZSPOPATTERNID - SPO Partitioning Pattern
- ZSPOPATTERNID1 - SPO Partitioning Pattern 1
- ZSPOPATTERNID2 - SPO Partitioning Pattern 2
- ZSPOPATTERNID3 - SPO Partitioning Pattern 3
- ZSPOPATTERNID4 - SPO Partitioning Pattern 4
- ZSPOTLOGO - SPO Object Type for DTP
SPO Partition Group
data:image/s3,"s3://crabby-images/1ce4e/1ce4e2e98e40434e84686a68114941fd1c62a8ae" alt="Data Element: ZSPOPARTGROUP"
SPO Partitioning Pattern
data:image/s3,"s3://crabby-images/0f410/0f410a22ea67c31d5b81bb7019e4f011a22f7309" alt="Data Element: ZSPOPATTERNID"
Note: The data elements ZSPOPATTERNID1, ZSPOPATTERNID2, ZSPOPATTERNID3 and ZSPOPATTERNID4 are defined like the ZSPOPATTERNID.
SPO Object Type for DTP
data:image/s3,"s3://crabby-images/45588/45588977deaf03d407fd68c44d16d93c71dc715b" alt="Data Element: ZSPOTLOGO"
We also implement a search help ZSPO_DTPTEMPLATE - SPO Templates
SPO Templates
data:image/s3,"s3://crabby-images/7e738/7e7383abfea1f9840a2ff743aeb3229837b093ba" alt="Search Help: ZSPO_DTPTEMPLATE"
Create Transparent Tables
After all these elements are created, we can now create the following transparent tables:
- ZSPOINFOPROV - SPO BAdI Managed InfoProvider
- ZSPOPATTERN - SPO Authorized Partition Pattern
- ZSPOPATTERNT - SPO Authorized Partition Pattern Text
- ZSPOCRITERIA - SPO Pattern Partition Criteria
- ZSPODTP - SPO BAdI Managed DTP
Table ZSPOPATTERN
The following fields have to be implemented:
- PATTERNID
- INFOOBJECT
data:image/s3,"s3://crabby-images/57ac5/57ac565ec7e2188acc0a853ff127aec6d7083190" alt="Table ZSPOPATTERN Fields"
This entry helps and checks have to be implemented:
data:image/s3,"s3://crabby-images/e5b45/e5b4559c4ad6792ac10838a118b8f9c7e401e86d" alt="Table ZSPOPATTERN Entry help/check"
data:image/s3,"s3://crabby-images/0ca63/0ca63796127962e9c72ab2d0aa2c4b4ee22858a9" alt="Table ZSPOPATTERN Foreign Key"
Table ZSPOPATTERNT
The following fields have to be implemented:
- LANGU
- PATTERNID
- TXTLG
- TXTSM
data:image/s3,"s3://crabby-images/c9939/c993954435f319941f58f17848f4974db2706754" alt="Table ZSPOPATTERNT Fields"
This entry helps and checks have to be implemented:
data:image/s3,"s3://crabby-images/e9fa2/e9fa2ec7135a117329c8cdb4a98bbd2b1ec6a669" alt="Table ZSPOPATTERNT Entry help/check"
data:image/s3,"s3://crabby-images/ca8a2/ca8a2af20f992370644d49131c18a9b96e6dea61" alt="Table ZSPOPATTERNT Foreign Key"
Table ZSPOCRITERIA
The following fields have to be implemented:
- PATTERNID
- PARTGROUP
- LOWVALUE
- HIGHVALUE
data:image/s3,"s3://crabby-images/0c1f9/0c1f9bcfbc3a6c57b5a9af2281ab2746cc832ffe" alt="Table ZSPOCRITERIA Fields"
This entry helps and checks have to be implemented:
data:image/s3,"s3://crabby-images/19e0e/19e0e71d8c58e2dab7b662ce62072e719b2ebd0a" alt="Table ZSPOCRITERIA Foreign Key"
Table ZSPOINFOPROV
The following fields have to be implemented:
- SPONAME
- PATTERNID1
- PATTERNID2
- PATTERNID3
- PATTERNID4
data:image/s3,"s3://crabby-images/7b6dd/7b6dd2ed6030dedcb799c32b14e9a1f74346d3f4" alt="Table ZSPOINFOPROV Fields"
This entry helps and checks have to be implemented:
data:image/s3,"s3://crabby-images/140b4/140b42d2a5c0607c40a280c524d801db59830159" alt="Table ZSPOINFOPROV Entry help/check"
data:image/s3,"s3://crabby-images/f7db2/f7db254d818649a85bb7770c62223afe468761f4" alt="Table ZSPOINFOPROV Foreign Key"
Table ZSPODTP
The following fields have to be implemented:
- SPONAME
- OBJTYPE
- OBJNAME
- LOGSYS
- DTPTEMPLATE
- DTPTEMPLATEID
data:image/s3,"s3://crabby-images/ddffe/ddffe7bb79b5cfb5ee36e508f433ce1953f2f5c2" alt="Table ZSPODTP Fields"
This entry helps and checks have to be implemented:
data:image/s3,"s3://crabby-images/c80d0/c80d066d8a46f1804c3c1042abcd83bf6f47a6d3" alt="Table ZSPODTP Entry help/check"
data:image/s3,"s3://crabby-images/bdb9b/bdb9bc98206ade20bee6af5803194d53f0b027b6" alt="Table ZSPODTP Foreign Key ZSPOINFOPROV"
data:image/s3,"s3://crabby-images/5fd06/5fd06258961792481184c0aad412009d35aecc66" alt="Table ZSPODTP Foreign Key TBDLS"
data:image/s3,"s3://crabby-images/19cea/19ceafd702572977eafd942e5806c2068e142a26" alt="Table ZSPODTP Foreign Key RSLPO_DFG_DTPTPL"
After we created all control tables, we can now create an implementation of BAdI RSLPO_BADI_PARTITIONING. How this works, can be read in Part 2.
These posts might also be interesting:
author.
I am Tobias, I write this blog since 2014, you can find me on twitter and youtube. If you want you can leave me a paypal coffee donation. You can also contact me directly if you want.
data:image/s3,"s3://crabby-images/59394/593941dc6ddcadf14871e651c4a36e48113e51b6" alt=""
data:image/s3,"s3://crabby-images/d3922/d3922ca64f54dc7d036ca544554b4f4284d4aaa4" alt=""
data:image/s3,"s3://crabby-images/a3cdf/a3cdfb01fe5da2c5160c1a472b2ef92fb28b5550" alt=""
Write a comment