UpdateEx 方法
用于更新基于输入键参数(key1、key2 … keyn)的属性。 使用 UpdateEx
时,不能删除集合中的项。 可使用单独方法进行删除。 有关详细信息,请参阅 DeleteOnly 方法。
语法
UpdateEx (key1, key2, ... keyn, correctionMode, interactiveMode,
properties)
参数
参数 | 说明 |
---|---|
key |
服务器数据库中必须存在的一组参数,或发生的错误。 这些键对应于为特定组件接口定义的一组 Get 键。 |
correctionMode |
布尔型标志。 设置为 true 时,可通过更新字段值或将新项插入集合来修改生效日期项的组件接口。 特别是,允许在当前生效日期之前修改具有 EFFDT 的项目。 如果此标志未设置为 TRUE,则对这些项目的任何修改将导致从 PeopleSoft 服务器返回错误。 参数 correctionMode 仅针对包含有效日期项的组件接口公开。 否则,不会作为参数的一部分显示。应避免在生产环境中将 设置为 correctionMode TRUE。 (这也是 PeopleSoft.) 事件的建议,这些事件已由过去的 EFFDT 键确定,不应修改。 允许创建审核记录。 中的 correctionMode UpdateEx 标志允许绕过此安全机制。 建议的做法是通过设置项目中的字段并添加(而不是删除)更新项目来停用过去的事件。 |
interactiveMode |
用于错误处理的标志。 访问组件接口中的属性时,PeopleSoft Enterprise 的 BizTalk 适配器使用 PeopleSoft 提供的用于读写组件接口中各个字段的 API;但是,这些更改并不是逐一传播到 PeopleSoft 服务器的。 psjoa.jar(与 PeopleSoft Enterprise 的 BizTalk 适配器交互)会将所有更改打包,然后将这些更改通过一个程序包发送到服务器。 如果各个更新中有任何一个失败,则会返回一般错误,但未指明确切问题。 将交互模式设置为 TRUE 时,每个字段更新都会单独发送到服务器。 这样会对性能产生实质影响,但是在更新失败的情况下(例如,如果使用无效的值设置字段)会提供特定错误信息。 interactiveMode 提供最佳性能,并在字段更新级别提供错误报告。 若要正确使用此功能,建议在设置为 FALSE 的情况下 interactiveMode 进行常规调用。 这应该不会对性能带来影响。 如果返回错误,可以在将 标志设置为 TRUE 的情况下 interactiveMode 重试相同的调用。 调用失败时,服务器将返回更准确的错误消息。 |
注解
调用此函数时,将使用输入参数属性替换与这些键相对应的记录的属性。 将删除原始记录的所有集合,并替换为输入参数中的集合。 这些集合的大小不必匹配,因为 中的 UpdateEx
过程是删除所有现有集合项,然后插入给定的集合项。
如果组件接口的属性包含生效日期项目,则属性参数必须包含所有未来的生效日期项目,因为原始列表已被替换。 这提供了添加和删除未来的生效日期项目的机制;但是,如果属性还包含过去的生效日期项目,则会因为无法修改过去的生效日期项目而返回错误。 如果还包含当前的生效日期项目,则将忽略该项目。 这允许客户端在参数设置为 False 的情况下getHistoryItems
调用 Get()
,修改任何未来的有效日期项或添加新的生效日期项,并将 结构作为函数的参数UpdateEx()
传入。
如果组件接口没有键(如只能存在一个实例的情况),则 UpdateEx()
方法的形式如下:
UpdateEx(correctionMode, interactiveMode, properties)
注意
如果启用了组件接口中的 PeopleSoft 和Save
函数,则会提供 BizTalk Adapter for PeopleSoft Get
Enterprise UpdateEx()
方法。