#2. One-to-Many (1:N) Relationships
This is a real example which illustrates a one-to-many relationship between one Location and many Devices.
From Device.py
... from Products.ZenRelations.RelSchema import * ... class Device(ManagedEntity, Commandable): ... event_key= portal_type = meta_type = 'Device' default_catalog= "deviceSearch" #device ZCatalog relationshipManagerPathRestriction = '/Devices' ... _relations = ManagedEntity._relations + ( ("location", ToOne(ToMany, "Location", "devices")), ) ...
From Location.py
... from Products.ZenRelations.RelSchema import * #
data:image/s3,"s3://crabby-images/94e99/94e999b902d858e6e62372f1b1f2633310b82803" alt="1.png"
data:image/s3,"s3://crabby-images/25742/257424aac5ec23daaf75b4cde334393af01be8d4" alt="2.png"
data:image/s3,"s3://crabby-images/b02d6/b02d625ea94c6b047cbefce1d19fe39743a7fb1b" alt="3.png"
data:image/s3,"s3://crabby-images/5b095/5b09546806b6e5af6dae2580f00c22c831bf48b5" alt="4.png"
According to this relationship there can be only one Location assigned to a Device but more than one Device assigned to a Location. This relationship is created by:
Importing ToOne and ToMany from Products.ZenRelations.RelSchema. | |
Appending a two-item tuple to the _relations attribute | |
The first item in the tuple is a "string" object which is the local name | |
The second item in the tuple is a RelSchema constructors takes three parameters:
|