Pipelet: Search SearchSystemObject
Pipelet SearchSystemObject
This pipelet searches for system object instances. The following system object types are supported:
- GiftCertificate
- Order
- Profile
- SourceCodeGroup
- Store
- ProductList
Output will be a SearchResult containing all object instances of the specified type that match the explicit SearchExpression OR the search criteria specified in Search*Key/Search*Value pairs. Please note: If search keys are specified by Search*Key parameters, the pipelet executes an ILIKE (case insensitive) query with right-hand wildcard on the values. This specific mode is typically for a "query by example" search in a user interface.
If no search criteria is provided the pipelet returns all object instances of the specified object type. In either case, SearchResultCount contains the number of objects in the SearchResult.
The identifier for an attribute to use in a query condition is always the ID of the attribute as defined in the type definition. For custom defined attributes the prefix custom is required in the search term (e.g. custom.color
), while for system attributes no prefix is used (e.g. name
).
Supported value types with sample expression values:
- String
'String'
- Integer
1, 3E4
- Number
1.0, 3.99E5
- Date
yyyy-MM-dd e.g. 2007-05-31 (Default TimeZone = UTC)
- DateTime
yyyy-MM-dd'T'hh:mm:ss+Z e.g. 2007-05-31T00:00+Z (Z TimeZone = UTC) or 2007-05-31T00:00:00
- Boolean
true, false
- Email
'search@demandware.com'
- Set of String
'String'
- Set of Integer
1, 3E4
- Set of Number
1.0, 3.99E5
- Enum of String
'String'
- Enum of Integer
1, 3E4
The following types of attributes are not queryable:
- Image
- HTML
- Text
- Quantity
- Password
Note, that some system attributes are not queryable by default regardless of the actual value type code.
The following operators are supported in a condition:
=
Equals - All types; supports NULL value (thumbnail = NULL
)!=
Not equals - All types; supports NULL value (thumbnail != NULL
)<
Less than - Integer, Number and Date types only>
Greater than - Integer, Number and Date types only<=
Less or equals than - Integer, Number and Date types only>=
Greater or equals than - Integer, Number and Date types onlyLIKE
Like - String types and Email only; use if leading or trailing wildcards will be used to support substring search(custom.country LIKE 'US*'
)ILIKE
Caseindependent Like - String types and Email only, use to support case insensitive query (custom.country ILIKE 'usa'
), does also support wildcards for substring matching
Conditions can be combined using logical expressions 'AND', 'OR' and 'NOT' and nested using parenthesis e.g. gender = {1} AND (age >= {2} OR (NOT profession LIKE {3}))
.
The pipelet provides a placeholder syntax to dynamically pass objects as search parameters. Each passed object is related to a placeholder in the SearchExpression configuration parameter. The placeholder must be an Integer that is surrounded by braces and relates to one of the input parameter Search*Value, e.g. custom.dtvalue <= {1}
.
The sorting order and direction can be specified by SortExpression OR by using the SortBy* / SortBy*Direction pairs. Please note that specifying a localized custom attribute as the sorting attribute is not supported.
Group:
Search
Configuration Properties
CaseSensitive : Boolean Optional
In case of a key/value based search definition the config value specifies whether a case sensitive or case insensitive LIKE is executed. Default is a case insensitive search.
Permissible Values:
false
true
ObjectType : String Required
The sytem object type to search for.
Permissible Values:
GiftCertificate
Order
ProductList
Profile
SourceCodeGroup
Store
SearchExpression : String Optional
The expression defining the search conditions. Samples: "firstName like 'Fred*' AND lastName like 'Incognito*'", "creationDate >= {1}", "email != NULL", "custom.ivalue = 1" The {1} points to an object value specified by dictionary-in parameter Search1Value.
SortExpression : String Optional
The expression defining the sorting conditions. Samples: "custom.ivalue ASC", "lastName DESC", "custom.ivalue ASC, creationDate DESC"
Input Parameters
Search1Key : String Optional
The ID identifying the attribute to search for. Samples: "creationDate", "custom.dtvalue"
Search1Value : Object Optional
The value to search for, an object of type String, Number, Date or Boolean.
Search2Key : String Optional
The ID identifying the attribute to search for. Samples: "creationDate", "custom.dtvalue"
Search2Value : Object Optional
The value to search for, an object of type String, Number, Date or Boolean.
Search3Key : String Optional
The ID identifying the attribute to search for. Samples: "creationDate", "custom.dtvalue"
Search3Value : Object Optional
The value to search for, an object of type String, Number, Date or Boolean.
Search4Key : String Optional
The ID identifying the attribute to search for. Samples: "creationDate", "custom.dtvalue"
Search4Value : Object Optional
The value to search for, an object of type String, Number, Date or Boolean.
Search5Key : String Optional
The ID identifying the attribute to search for. Samples: "creationDate", "custom.dtvalue"
Search5Value : Object Optional
The value to search for, an object of type String, Number, Date or Boolean.
SortBy1 : String Optional
The ID identifying a sorting attribute. Samples: "creationDate", "custom.dtvalue"
SortBy1Direction : Number Optional
Specifies the sorting direction of the related sorting attribute. (1 = ASC, other value = DESC)
SortBy2 : String Optional
The ID identifying a sorting attribute. Samples: "creationDate", "custom.dtvalue"
SortBy2Direction : Number Optional
Specifies the sorting direction of the related sorting attribute. (1 = ASC, other value = DESC)
SortBy3 : String Optional
The ID identifying a sorting attribute. Samples: "creationDate", "custom.dtvalue"
SortBy3Direction : String Optional
Specifies the sorting direction of the related sorting attribute. (1 = ASC, other value = DESC)
Output Parameters
SearchResult : Iterator : Optional
The system object instances that match the search criteria.
SearchResultCount : Integer : Optional
The number of system object instances in the SearchResult.