Slow retrieving items from Outlook

S

Simon Maystre

I am accessing Outlook from Access VBA and whilst the following code works
just fine it seems really slow to just show a list of the mail items that are
in the Inbox are there any suggestions on how this could be speeded up.

Set objFolder = objOutlook.GetNamespace("MAPI").GetDefaultFolder(MailBox)

With objFolder

lngCount = .Items.Count

If lngCount > 0 Then

For Each objOutlookMail In .Items

aryEmails(1, lngCount2) = Nz(objOutlookMail.To, "")
aryEmails(2, lngCount2) = Nz(objOutlookMail.Subject, "")
aryEmails(3, lngCount2) = objOutlookMail.Senton

lngCount2 = lngCount2 + 1

Next

End If

End With

Many thanks
 
S

Sue Mosher [MVP-Outlook]

Try using the SetColumns method to retrieve only those properties that you're interested in, e.g.:

.Item.SetColumns ("To, Subject, SentOn")

--
Sue Mosher, Outlook MVP
Author of Configuring Microsoft Outlook 2003

and Microsoft Outlook Programming - Jumpstart for
Administrators, Power Users, and Developers
 
S

Simon Maystre

This did the trick to speed up the load by around 500%! I also changed how I
was referencing the item object slightly and this also improved load time:

Thanks for your help.

Set objFolder = objOutlook.GetNamespace("MAPI").GetDefaultFolder(MailBox)
Set objOutlookItems = objFolder.Items

With objOutlookItems

.SetColumns ("From, To, SenderName, Subject, SentOn")
lngCount = .Count

If lngCount > 0 Then

ReDim aryEmails(3, lngCount - 1)

For lngCount2 = 1 To lngCount

aryEmails(0, lngCount2 - 1) = lngCount2

If MailBox = 5 Then
aryEmails(1, lngCount2 - 1) = Nz(.Item(lngCount2).To, "")
Else
aryEmails(1, lngCount2 - 1) =
Nz(.Item(lngCount2).SenderName, "")
End If

aryEmails(2, lngCount2 - 1) = Nz(.Item(lngCount2).Subject, "")
aryEmails(3, lngCount2 - 1) = .Item(lngCount2).SentOn
Progress lngCount2

Next

End If

End With
 
V

VOORSPRONG

Sue,

I am looking for a list of the column names to select from to pass with
SetColumns. I can get some columns to work but not all. Would you have the
list for me? Nice when mapped to the functions like SenderName, ReceivedTime
etc.

I also found out that when I pass multiple columnnames in one string with
SetColumns the performance is as poor as without but when I add the selected
columns in individual instructions I do have the performance.
 
K

Ken Slovak - [MVP - Outlook]

The Outlook VBA Object Browser Help has a list of what properties you cannot
use with SetColumns. Any other properties not listed there can be used with
SetColumns.

Speed with SetColumns and multiple properties is faster than not using
SetColumns. The gain in speed is related to how many columns you ask for and
how large those columns are. If any are larger than can be retrieved using a
MAPITable then retrieving that property will require falling back to an
IStream to retrieve the property, thereby cutting the speed somewhat.
 
V

VOORSPRONG

Ken,

Thanks for the answer.

Two issues; Are the column names identically to the property names and if so
why does SenderName when passed as string not return a value when the
property SenderName is requested. Second; I am not using VBA but a likewise
COM solution (Visual DataFlex). And in VBA when I went to the SetColumns
instruction I only saw that I needed to enter a string.

Regards,
Vincent Oorsprong
Data Access Europe B.V.
Netherlands
 
K

Ken Slovak - [MVP - Outlook]

Select SetColumns in the Object Browser and click F1. That will open the
Help which has the list of properties you cannot use. All properties use
their object model names. If SenderName is not blank in the items it should
be returned.
 
K

Ken Slovak - [MVP - Outlook]

As I said before, whatever is not listed as being a property to not use can
be used. So anything not listed there can be used.
 
V

VOORSPRONG

You do not (want to) understand my question. I want to have a the list of
names and not a hint like look at the property names. They simply do not 100%
match! You must have a list somewhere. Why not document this appropriately?

Regards,
Vincent Oorsprong
Data Access Europe B.V.
Netherlands
 
K

Ken Slovak - [MVP - Outlook]

I don't work for Microsoft, and this is a peer to peer forum.

I don't have a list of the properties you can use, and as far as I know
there is none.

If you want to open a support case with MS and ask for a list like that go
ahead and do it.

I can only provide you with the information that's available, and what you
want is not available. I gave you the best possible answer, if you don't
like it then I can't help you any further.
 
V

VOORSPRONG

Ok, I assumed you were an Microsoft employee and simply did not want to find,
compile the list. Sorry. But it is sad that the documentation is so poor,
certainly from a company as Microsoft with lots of good and available
resources. And this is not only in Office products.

Regards,
Vincent Oorsprong
Data Access Europe B.V.
The Netherlands
 

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Top