Filtering Items
This topic describes the general rules for specifying properties in filters that are supported by various objects in Outlook. See the topics in the Filter Syntax section for further information on specifying conditions on properties to complete a filter.
A filter is a condition or a set of conditions that you can apply to a set of items in order to obtain a subset of items that meets the specified conditions. Outlook supports filters using the Microsoft Jet query language syntax or the DAV Searching and Locating (DASL) syntax. Note that the Jet query language syntax has the same syntax as that supported by Microsoft Jet Expression Service, hence the name Jet query language.
As an example, you can filter contact items in your Contacts folder to obtain a list of contacts residing in Canada. In this case, you will be filtering on the HomeAddressCountry property. The filter, expressed as a Jet filter, will be "[HomeAddressCountry] = 'Canada'".
Outlook provides filtering through the following entry points:
Entry Point |
Jet Filter Support |
DASL Filter Support |
No |
Yes |
|
Yes |
Yes |
|
Yes |
Yes. Note that if you use the query keywords ci_phrasematch or ci_startswith in the filter, you will get an error. |
|
Yes |
Yes |
|
No |
Yes |
|
Yes |
Yes. Note that if you use the query keywords ci_phrasematch or ci_startswith in the filter, you will get an error. |
|
Yes |
Yes |
|
No |
Yes |
Note
A filter must contain a query in either Jet or DASL syntax but not a mixture of both.
Property Specifiers
When specifying properties in a Jet filter or DASL filter using any of the above entry points, follow these guidelines:
Jet Filter |
DASL Filter |
|
Applicable Properties |
Most explicit built-in and custom item-level properties; see corresponding method topic for unsupported properties. |
Most built-in and custom item-level properties with and without explicit string names; see corresponding method topic for unsupported properties. |
Referencing Properties |
|
By their namespaces. |
Format of Reference |
|
|
Error Conditions |
Returns an error if a custom property in the filter is not defined, or the filter is empty, has an invalid argument, or cannot be parsed. |
Returns an error if a custom property in the filter is not defined, or the filter is empty, has an invalid argument, or cannot be parsed. |
Filter Syntax
The syntax of a filter depends on the type of the property you are filtering on. The following topics provide further information on how to construct a filter based on a specific property type: