SAP CRM settype的建立,背后发生了什么

来自个人同事Sara。数据库

当咱们在CRM系统里建立一个settype以后,其实系统后台悄悄的帮咱们建立了不少ABAP对象,好比对应的database tables, other ABAP Dictionary objects, function groups, function modules, and screens等等。 Create set types:框架

DB check:自动建立了一个和settype ID同名的数据库表ui

问题:How this DB generate? How to check what function groups, function modules, and screens are created? Especially which screens? When we assign the attributes to the set type, I guess it will insert lines into the table.this

Jerry的解答:spa

当你建立一个新的settype时,product框架会自动生成针对该settype的structure和存储Table, 以及对应的用于CRUD的function module。可是了解框架自己如何实现我前面说的这些事情,对咱们接下来作的co deployment没有直接帮助。你的这个问题能够转换成:3d

假设我只知道product的description字段是经过某个settype实现的,我想不问别人,本身弄清楚该settype的名字和访问该settype的CRUD的function module名字,该如何作?code

I got one information from my colleague, the Product Description function is implemented by the SAP standard set type. Then I want to make clear: (1) Which standard set type implement Product Description and it's DB table? (2) Which function module (API) implement the CRUD of Product Description?orm

写在前面:本文说起的方法只限一种思路,不排除个别Assignment Block 不适用的情景,请你们广开思路,积极探索更多的方法来研究,但愿能总结出更多的具体API,简化每个功能的实现。对象

Product ID: SZIPC (in QHD) After this self study, I can get a general knowledge of how the product fields implemented in the SAP System.blog

Then I will start this self study step-by-step by question driven.

(1) Which standard set type implement Product Description?

Try Google it first. Wow, got some information. set type name COMM_PR_SHTEXT.

(2) Is it right? How can I display set type? One way, Google.

Second way, I would like to use SE93 to find transaction code by transaction description, got it! TCODE: COMM_SETTYPE

There is some issue, you can not display set type by TCODE: COMM_SETTYPE directly, you can only use COMM_ATTRSET input the set type COMM_PR_SHTEXT first the sue TCODE: COMM_SETTYPE to dispaly.

(3) Then how can I find the DB for this set type and the CRUD function model?

There is 2 ways.

The first way, is to use TCODE: ST05 trace. I update the description from Material_Sara to Material_SaraZhang. I search with key words 'Material_SaraZhang', then I find the DB--COMM_PORTEXT.

The second way, I would like to use TCODE: SE93 find the package of TCODE COMM_SETTYPE.-- Assume,I do not know, Most of the Set Type name = DB Table name.

There must be a table include all the Set Type name and DB Table names, how can I find it? This is an important thinking point, for every TCODE in SAP, it's a collection of multiple functions /tables/views. Which should be packaged in a package.

In the package, there is multiple DB, from the DB description, you can know COMC_SETTYPE is the admin table which include all information we want.--Admin table and header table always as the start and base point of DB relationship.

Filter by the set type name** COMM_PR_SHTEXT**, we found the set type DB COMM_PRSHTEXT and related function module.

(4) How the function module work when I read the product description?

TCODE: SE37 find COM_COMM_PR_SHTEXT_READ_WITH_P and set breakpoint.

search Product ID: SZIPC

in WebClient UI.

Follow the call stack, find the key API for read product set types.

(5) How the function module work when I Update the product description?

Function Module: COM_COMM_PR_SHTEXT_MAINTAIN_UP Follow the call stack, find the key API for update product set types.

(6) I will try to simplify this function module, pick this function into a report for confirming how does this CALL FUNCTION 'CRM_PRODUCT_UI_GETDETAIL' work?

This is the key function for processing product set types.

We'd better to understand it's indeed input value One, is product guid in a structure. Two, is the set type name. It means that, any set type can read by this function.

要获取更多Jerry的原创文章,请关注公众号"汪子熙":

相关文章
相关标签/搜索