0

背景:

我有几个表在视图集群(SE54)中连接以进行维护。这些表中的每一个都有标准的创建/更改者/日期字段。对于创建的数据,更新字段很容易,我在表维护生成器中使用事件 05(创建时)。对于默认更改的字段,它涉及更多一点。我必须使用事件 01(保存前),然后根据需要更新表TOTAL[]EXTRACT[]字段值。

在 SM30 中维护表时, 和 的格式TOTAL[]EXTRACT[]我正在维护的视图相同,并带有一个附加标志来标识进行了哪种类型的更改(更新/创建/删除)

但是,在SM54中维护时(这是业务需求),TOTAL[]and的格式EXTRACT[]只是一个字符行的内部表。

问题:

我可以弄清楚正在编辑的表格的类型是什么。但是当我尝试将字符行移动到类型行时,出现以下运行时错误:(取决于我尝试移动/分配它的方式)

ASSIGN_BASE_TOO_SHORT
UC_OBJECTS_NOT_CONVERTIBLE
UC_OBJECTS_NOT_CHAR

我所有的结构都采用以下格式:

*several generic (flat) types
CREATED    TYPE TMSTMP,  "not a flat type
CHANGED    TYPE TMSTMP,  "not a flat type
CREATED_BY TYPE ERNAM,
CHANGED_BY TYPE AENAM,

问题的根源在于这两个时间戳字段不是平面类型。我可以在字符行中看到时间戳由 8 个字符表示。

编辑:只有在找到解决方案后,我才能将 Length(8) 字段识别为已打包。

我徒劳地尝试了以下方法:

"try the entire structure - which would be ideal
assign ls_table_line to <fs_of_the_correct_type> casting.  

"try isolating just the timestamp field(s)
assign <just_the_8char_representation> to <fs_of_type_tmpstmp> casting.

我已经尝试了“仅单个字段”选项的其他一些变体,但没有运气。

有什么想法可以从 Character 类型转换为 TSTMMP 类型,然后再返回以更新内部表值?

4

1 回答 1

3

我发现以下工作:

而不是使用:

field-symbols: <structure> type ty_mystructure,
               <changed>   type tmstmp.

assign gv_sapsingle_line to <structure> casting. "causes a runtime error
assign gv_sap_p8_field   to <changed> casting.   "ditto

我用这个:

field-symbols: <structure> type any,
               <changed>   type any.

assign gv_sapsingle_line to <structure> casting type ty_mystructure.
assign gv_sap_p8_field   to <changed> casting type ty_tmstmp.   

出于某种原因,它不喜欢我预定义了字段符号。

我发现这很奇怪,因为文档说明了以下内容:

使用隐式类型声明进行强制转换 如果字段符号是完全类型的或具有通用内置 ABAP 类型之一——C、N、P 或 X——您可以使用以下语句:

ASSIGN ... TO <FS> CASTING.

当系统访问字段符号时,分配的数据对象的内容被解释为与字段符号具有相同的类型。

我只能假设我的结构不兼容(由于 P8 -> TSTMMP 转换)

数据对象的长度和对齐方式必须与字段符号类型兼容。否则系统返回运行时错误。如果字段符号或数据对象的类型是(或包含)字符串、引用类型或内部表,则这些组件的类型和位置必须完全匹配。否则,会发生运行时错误。

于 2013-06-10T03:52:34.830 回答