Help and Support

Article ID: 116140 - Last Review: January 19, 2007 - Revision: 2.3

ACC: How to Pass an Array as an Argument to a Procedure

This article was previously published under Q116140
Moderate: Requires basic macro, coding, and interoperability skills.

On This Page

Expand all | Collapse all

SUMMARY

In order for a procedure to accept an array as an argument, the procedure must declare the array argument, with opening and closing parentheses after the argument name. Additionally, when passing the array to the procedure, you must include parentheses after the array name, unless you are using Visual Basic. Otherwise, you may receive the error message "Parameter type mismatch" or "Duplicate definition."

This article assumes that you are familiar with Visual Basic for Applications and with creating Microsoft Access applications using the programming tools provided with Microsoft Access. For more information about Visual Basic for Applications, please refer to your version of the "Building Applications with Microsoft Access" manual.

NOTE: Visual Basic for Applications is called Access Basic in Microsoft Access versions 1.x and 2.0. For more information about Access Basic, please refer to the "Introduction to Programming" manual in Microsoft Access version 1.x or the "Building Applications" manual in Microsoft Access version 2.0

MORE INFORMATION

The following example demonstrates the correct syntax for procedure declarations with an array:
   Function YourFunctionName (InArray() As String) As Integer

   Sub YourSubName (InArray() As String)
				
The following example demonstrates the correct syntax for procedure calls with an array:
   Result = YourFunctionName(YourArrayName())

   YourSubName YourArrayName()
				
NOTE: When calling procedures in Visual Basic, you do not have to include the opening and closing parentheses after "YourArrayName" in the above example.

Example

The following example demonstrates a sample user-defined function that loads an array with string values:
  1. Create a new module and enter the following code:

    NOTE: In the following sample code, an underscore (_) at the end of a line is used as a line-continuation character. Remove the underscore from the end of the line when re-creating this code in Access Basic.
     '---------------------------------------------------------------
          'GLOBAL DECLARATIONS SECTION
          '---------------------------------------------------------------
          Option Explicit
    
          '---------------------------------------------------------------
          'The function LoadArray() loads an array called MyArray
          'with string values. After loading the array, the function
          'calls a procedure that displays each array element
          'in a message box.
          '---------------------------------------------------------------
    
          Function LoadArray()
             Dim i as Integer
             ReDim MyArray(10) As String
             For i = 1 to 10
                MyArray(i) = "Test Value: " & i
             Next i
             DisplayArray MyArray()
          End Function
    
          '---------------------------------------------------------------
          'LoadArray() Sub Procedure
          '---------------------------------------------------------------
    
          Sub DisplayArray (InArray() As String)
             Dim i as Integer
             For i = 1 to UBound(InArray)
                MsgBox InArray(i)
             Next i
          End Sub
    
    						
  2. On the View menu, click Debug Window (or Immediate Window in versions 1.x and 2.0)
  3. Type the following line, and then press ENTER:
    ? LoadArray()

REFERENCES

For more information about Arrays, search the Help Index for "Arrays."

APPLIES TO
  • Microsoft Access 1.0 Standard Edition
  • Microsoft Access 1.1 Standard Edition
  • Microsoft Access 2.0 Standard Edition
  • Microsoft Access 95 Standard Edition
  • Microsoft Access 97 Standard Edition
Keywords: 
kbhowto kbprogramming KB116140
Retired KB ArticleRetired KB Content Disclaimer
This article was written about products for which Microsoft no longer offers support. Therefore, this article is offered "as is" and will no longer be updated.

Article Translations