Attribute join
 
    
As with an Attribute projection, an Attribute join returns all or selected attribute values of the attribute type selected via the Attribute parameter. This is based on the main entity of the search or a different Attribute owner path.
The possible uses for the Attribute join in the context of different attribute types are illustrated by the following case differentiation:
| Cardinality of the attribute/subtype ↓ | Attribute type is non-typed | Attribute type is typed | |
| specific subtype | all subtypes | ||
| 'singular' (≤1) | Default access: | 
 | An Attribute join evaluates instances for all singular and plural subtypes and returns a 'flat' list that can be accessed by Projections. | 
| 'plural' (≥1:) | Attribute join is the default access | ||
- A non-typed singular attribute can be selected as an Attribute. Technically, an Attribute join therefore provides access to the value of a singular attribute. However, the Singular attribute join provides the same result. 
- For a non-typed plural Attribute, e.g. the 'communication information' (AddressCommunicationInfo) for the entity type 'Address' (Address), an Attribute join represents the default join. 
- If the Attribute selection relates to an attribute type from the group of typed attributes (e.g. 'text attribute' or 'company and address attribute'), the Attribute join provides the attribute values of all singular and plural subtypes as a 'flat list'. - The typed attributes with a plural subtype therefore do not appear 'grouped' or 'bundled' per attribute owner and subtype in the return value, but as individual attribute values (with the same subtype but different index value. 
 
In contrast to Attribute projection, the list of return values for an Attribute join can be restricted to a subset using a On condition.
Configuration
| Parameter | Data type | Description | 
| Specific parameters | ||
| Attribute owner path | Entity | An Attribute owner path only needs to be explicitly defined by configuring a projection (see Projections) if the entity in the context of the search is not the owner of the attributes that are to be evaluated. This is relevant in the following cases, for example: 
 | 
| Attribute | Class | In the Combobox element for the Attribute parameter, a selection must be made from the attribute type options offered via a dropdown. Only the attribute types supported by the implementation of the entity type of the applicable attribute owner are available for selection here. ►NOTE◄ If no options are available for the Attribute or if options are missing, then the Attribute owner path may not have been set appropriately (e.g. the 'Address' of an account for which no attributes are implemented). | 
| Generic parameters | ||
| Join alias, Join type, Optional, On condition see Entity join | ||
Examples
Typical use case: Selective access to a plural attribute
A CSV search for Users should list e-mail addresses for each 'Username' (username) specified for this user via the 'communication information' plural attribute of the user's address.
If there are multiple types of 'communication information' with the Communication type 'E-mail' (EMAIL) for a user, this should be output line by line (as multiple lines for the same user).
If a 'context' (communicationContext) is specified in the 'communication information' attribute, this text value should appear in the output column (CONTEXT).
Configuration:
| The Attribute join shown on the right is created within a CSV search for Users: 
 | 
 | |
| The output columns are defined by three instances of the Property projection: 
 | 
 | Runtime example: username,email.communicationValue,email.communicationContext | 
Special use case: Access to several subtypes of a typed attribute
The company address (as attribute owner) can be used to assign address contacts to a company account. The relevant data is in turn Addresses, which are treated as a typed attribute of the 'Address contact' (AddressContact) type, whereby a Contact type is assigned. A Tuple search for Companies/Clients is enriched with the address data of all address contacts whose Contact type is either 'CEO' (CEO) or 'Employee' (EMPLOYEE).
Configuration:
 
    
The Attribute join shown above provides the desired address contacts via the following parameterization:
- The Attribute owner path accesses the 'Address' (address) property of the company account via a Property projection. 
- The attribute type 'Address contact' (AddressContact) is selected in the Attribute parameter. 
- The name staff is arbitrarily assigned as the Join alias. 
- The 'Inner' Join type ensures that only Companies/Clients for which at least one address contact exists are taken into account. 
- The Optional option is irrelevant, as Projections for output columns (see below) address the alias staff. 
- The On condition uses a Search junction that ORs two instances of the Property projection: - The first Property projection determines whether the 'Type' property of an address contact specifies 'Managing Director' (CEO) as the Contact type. 
- The first Property projection determines whether the 'Type' property of an address contact specifies 'Employee' (EMPLOYEE) as the Contact type. 
 
| The output columns are defined by three instances of the Property projection as shown on the right: 
 | 
 | 
 
     
    