AfterLoading事件已触发2次

2020-09-09 18:39发布

点击此处---> 群内免费提供SAP练习系统(在群公告中)加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)大家好, 我创建了一个与...

         点击此处--->   EasySAP.com群内免费提供SAP练习系统(在群公告中)

加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)


大家好,

我创建了一个与该员工关联的新CustomBO。 要求是根据与该登录用户的员工CostomBO相关的值,使该CustomBO中的某些字段对于登录的用户隐藏起来。

在这种情况下,如果要显示员工A 的CustomBo字段,则在Event-AfterLoading中创建了以下代码。

1。 读取当前用户B

2。 读取此用户B的关联员工B

3。 阅读用户B的CustomBO

4。 ->执行查询后," this"-对象(来自A的数据)被B覆盖,因为在查询过程中触发了AfterLoading事件。

没有" this"的读取自定义BO B如何从db更改为原始数据?

感谢帮助!

关于此:

查询中ExecuteDataOnly(),ExecuteFromDBDataOnly(),ExecuteFromDB()和Execute()有什么区别?

AGetFromDB的用途是什么?

(37.5 kB)
1条回答
CJones
2020-09-09 18:53

约翰尼斯,你好

解释检索结果的不同方法:

Execute-从数据库返回实例,尝试从缓冲区中检索数据。

ExecuteDataOnly-仅返回所查询节点的实例。

ExecuteFromDB-行为类似于execute,但不检查查询节点的缓冲区。

ExecuteFromDBDataOnly-仅返回所查询节点的实例,而不检查缓冲区。

GetFromDB-从数据库中返回查询节点和节点集合的实例,包括从属对象节点和扩展节点。 如果要将缓冲区值与数据库值进行比较,这很有用。

现在可以很清楚地回答您的问题" this"使用"。"获取缓冲区数据。 查询结果中的运算符(例如" BusinessPartner.Address.Street")将从缓冲区中检索数据,除非您使用的是GetFromDB函数。 根据您是否要使用数据库值的缓冲区值,可以选择这些功能。

我希望这会有所帮助,

拍子。

一周热门 更多>