I recently encountered an issue when adding a DB View based EBC to a BO. When I attempted to perform a MergeRecords operation on two records in the primary BC (Contact in this case), I got an error:
[1] An error has occurred writing to a record
Please continue or ask your system administrator to check your application configuration if the problem persists.(SBL-DBC-00111)
[2]ORA-06550: line 137, column 15:
PL/SQL: ORA-01031: insufficient privleges
ORA-06550: line 137, column 1:
PL/SQL: SQL Statement ignored
It turns out this error is caused because siebel is attempting to update a column in a DB View. Why would it try to do that you might ask?
If we reverse engineer what is happening, we find that when
performing a MergeRecords operation, Siebel determines the underlying table of the
active business component and uses the SRF to find all links where the
identified table is shared with the source business component of the Link and
the source field is ‘Id’ (or null which is the same thing). The merge algorithm then takes this list to
write the SQL to update the appropriate destination field to the new value of
the Id field on the Source BC. Since
merge is a data integrity operation, the use of Links using the ‘Id’ field is a
proxy for those links configured to have a data integrity implication.
Ideally, Siebel would provide a configurable
mechanism to exclude a particular link from a Merge, or, at a minimum, to recognize
that when a link points to a destination BC that is based on a table object
whose type is ‘External View’, no update is possible and hence should not be attempted. Alas that is not the case.
Therefore a way to trick the algorithm into
excluding this link is to define the link on one which is not based on data
integrity, and instead make it just informational. This can be done by making the Source field
of the link something other than Id. But
since we do not want to actually change the definition of the view this link
points to, a column whose value matches the ROW_ID column is desireable. In the case of the Contact BC, there are a
couple of potential options. PERSON_UID
defaults to the Id field but since this column might be populated by EIM to be a
value other than it’s ultimate row id, the values may not match on that data
set. But since Contact is based on the
Party model, the PAR_ROW_ID should always match since this points to the
S_PARTY record and the same ROW_ID is always used. This column is not exposed
on the Contact BC though so it needs to first be exposed and then the new BC
field can be used in the links.
No comments:
Post a Comment