This wiki has undergone a migration to Confluence found Here
<meta name="googlebot" content="noindex">

Object nets and object trees

From HL7Wiki
Revision as of 16:36, 27 February 2010 by Rene spronk (talk | contribs)
Jump to navigation Jump to search

Summary

  • v3 artefacts, when used in a messaging context, are object trees. When one persists these in a RIMBAA application all objects that share one and the same id are 'merged' into one single object. A stack of trees where objects interconnect based on their shared identity is an object net. Object nets have different characteristics than object trees, e.g. in areas such as context conduction, querying of object net subsets, and object versioning.

Related: Context Conduction in cyclic RIM graphs

Analysis

  • Ewout has taken the action item to write an analysis.

Discussion

  • Rene: this is again related to the issue of identity of objects. The business identity of a RIM class is contained in its Id attribute (for Acts, Entities and -managed- Participations). For Roles identity is based on the tuple (Role.id, 'Scoper') where 'Scoper' could be an Entity.id or an Entity.name.
    • This is especially relevant in the process of deciding when to 'merge' objects into an object net.
    • Example: a RIMBAA application persists an Observation with subject Patient 123 with scoping entity 'hospital A'.
      1. If it subsequently receives an object tree with Procedure with subject Patient 123 with scoping entity 'hospital A' - in that case the patient objects are one and the same.
      2. If it subsequently receives an object tree with Procedure with subject Patient 123 with scoping entity 'hospital B' - the objects won't be merged - they're not the same.