Tips for Better Table Performance
Last modified: January 16, 2009
Applies to: Office 2010 | Outlook 2010 | Visual Studio
Because many of the table operations can be time-consuming and there is no way to indicate progress, it is helpful to use the following techniques for improving performance:
Make IMAPITable calls in the correct order
Clients and service providers can work with tables in a variety of ways. They can open the table and retrieve the data for all of the rows using the default column set and sort order. Alternatively, they can modify this default view of the table by changing the column set, changing the sort order, or establishing a restriction to narrow the table's scope. Table users that intend to perform one or more of these operations before retrieving any data should perform them in the following order:
Define a column set with IMAPITable::SetColumns.
Establish a restriction with IMAPITable::Restrict.
Define a sort order with IMAPITable::SortTable.
Performing these tasks in this order limits the number of rows and columns that will be sorted, thereby improving performance.
Delay an operation using the TBL_BATCH flag if possible
Setting the TBL_BATCH flag on a method allows the table implementer to collect several calls before acting on any one of them. Instead of make potentially many calls to a remote server; a table implementer can make one, performing all the operations at one time. The results of the operations are not evaluated until they are needed. For example, when a client calls IMAPITable::Restrict to specify a restriction with the TBL_BATCH flag set, the restriction do not have to go into effect until the client calls IMAPITable::QueryRows to retrieve the data. This allows the table implementer to combine the work of two calls into one. Table users that take advantage of the TBL_BATCH flag should be aware that error handling under these conditions can be more complex. Because handling the errors from a delayed operation is similar to handling the errors when the MAPI_DEFERRED_ERRORS flag is set, see Deferring MAPI Errors for more information.
Keep a cache of commonly used properties
Service providers implementing tables can lessen the time it takes to create a view by caching copies of commonly used object properties. Keeping a copy of these properties in memory saves having to retrieve them from the object each time the view must be rebuilt.