Access VBA - Post Course
Access VBA - Post Course
Access
VBA Introduction
                       MicrosoftTraining.net
                                    Certified Silver Partner
 Accredited Learning Provider
WELCOME TO YOUR ACCESS VBA INTRODUCTION
TRAINING COURSE
         MicrosoftTraining.net/Feedback
                                          CONTENTS
Visual Basic for Applications or VBA is a development environment built into the
Microsoft Office Suite of products.
In Access worksheets, tables, forms, reports and queries are also objects.
              House          42               Fix
English       .noun          .noun            .verb
When working in VBA tell Access exactly what to do. Don’t assume anything.
                 Project
                 Explorer
Code Window
    Properties
    Window
    Title bar, Menu bar     The centre of the Visual basic environment. The
    and Standard            menu bar and toolbar can be hidden of customized.
    toolbar                 Closing this window closes the program.
    Code Window             Used to edit the Visual basic code. Press F7 and it
                            will open an object selected in Project Explorer.
                            Close the window with the Close button that
                            appears on the menu bar.
If the Visual Basic Help files are installed, by pressing F1, a help screen displays
explaining the feature that is currently active:
Alternatively use the Ask a Question box on the menu bar to as a quick way to find
help on a topic.
OR
Press Alt + Q
OR
Procedure is a term that refers to a unit of code created to perform a specific task. In
Access, procedures are stored in objects called Modules.
Standard modules can be used to store procedures that are available to all objects in
your application
Within a project you can create as many standard modules as required. You should
store related procedures together within the same module.
Standard modules are also used to declare global variables and constants.
A procedure is a named set of instructions that does something within the application.
To execute the code in a procedure you refer to it by name from within another
procedure. This is known as Calling a procedure. When a procedure has finished
executing it returns control to the procedure from which it was called.
If you require 10 stages to solve a problem write 10 sub procedures. It is easier to find
errors in smaller procedures than in a large one.
Naming Procedures
There are rules and conventions that must be followed when naming procedures in
Visual Basic.
While rules must be followed or an error will result, conventions are there as a
guideline to make your code easier to follow and understand.
Use the proper case for the word within the procedure name
           If procedures are related try and place the words that vary at the end of the
           name
PrintClientList
GetDateStart
GetDateFinish
Creating a Sub-Procedure
Most Access tasks can be automated by creating procedures. This can be done by
either recording a macro or entering the code directly into the VB Editor’s Code
window.
Statement block
End Sub
Public indicates procedure can be called from within other modules. It is the default
setting
Private indicates the procedure is only available to other procedures in the same
module.
The Sub…End Sub structure can be typed directly into the code window or inserted
using the Add Procedure dialog box.
Function procedures are similar to built-in functions such as DateDiff(). They are
sometimes called user-defined function.
A function returns a value to the procedure that calls it. The value the function
generates is assigned to the name of the function.
[Statement block]
[FunctionName = <expression>]
End Function
Public indicates procedure can be called from within other modules. It is the default
setting
Private indicates the procedure is only available to other procedures in the same
module.
The As clause sets the data type of the function’s arguments and return value.
Calling Procedures
A sub procedure or function is called from the point in another procedure where you
want the code to execute. The procedure being called must be accessible to the calling
procedure. This means it must be in the same module or be declared public.
Sub procedure
Function procedure
When passing multiple arguments (as in the function procedure above) always
separate them with commas and pass them in the same order as they are listed in the
syntax.
Auto Quick Info is a feature of the Visual Basic that displays a syntax box when you
type a procedure or function name.
The example below shows the tip for the Message Box function:
Type in a module:
Function Age(StartDate)
Age=Int((Date-StartDate)/365.25)
End Function
If we have a hire date for staff members and some of them also have an end date
(They have left the company). We can amend the Age function with an Optional
Argument. An If decision code is used to tell the function how to use the Optional
argument.
End Function
Application.FollowHyperlink “http://www.google.co.uk/maps/search/”&Address
End Function
The Immediate window is a debugging feature of Visual Basic. It can be used to enter
commands and evaluate expressions.
Code stored in a sub or function procedure can be executed by calling the procedure
from the Immediate window.
OR
Press Ctrl+G.
To evaluate an expression:
       Type ? Expression
       Press Enter.
Within the code, especially in loops, use the Debug.Print statement to display values
in the Immediate window while the code is executing. The Immediate window must be
open for this.
The Code Editor window is used to edit Visual Basic code. The two drop down lists can
be used to display different procedures within a standard module or objects’ event
procedures within a class module.
     Procedure List       Displays a list of general procedures in the current module when
                          General is selected in the Object list.
                          When an object is selected in the Object list it displays a list of
                          events associated with the object.
Select Options.
Require Variable      Adds the line Option Explicit to all newly created modules, requiring
Declaration           all variables to be explicitly declared before they are used in a
                      statement.
Auto List             Displays a list box under your insertion point after you type an
Members               identifiable object. The list shows all members of the object class.
                      An item selected from the list can be inserted into your code by
                      pressing the Tab key
Auto Quick Info       Displays a syntax box showing a list of arguments when a method,
                      procedure or function name is typed
Auto Data Tips Displays the value of a variable when you point to it with a mouse
Auto Indent   Indent the specified amount when Tab is pressed and indents all
              subsequent lines at the same level.
Drag-and-Drop Text Editing       Allows you to drag and drop code around the Code
                                 window and into other windows like the Immediate
                                 window.
Default to Full Module View      Displays all module procedures in one list with
                                 optional separator lines between each procedure.
                                 The alternative is to show one procedure at a time,
                                 as selected through the Procedure list.
Editing Guidelines
       If a statement is too long carry it over to the next line by typing a space and
       underscore ( _ ) character at the end of the line. This also works for comments.
   Strings that are continued require a closing quote, an ampersand (&), and a space
   before the underscore. This is called Command Line Continuation.
       Complete statements by pressing Enter or by moving focus off the code line by
       clicking somewhere else with the mouse or pressing an arrow key.
    When focus is moved off the code line, the code formatter automatically places key
    words in the proper case, adjusts spacing, adds punctuation and standardizes
    variable capitalization.
It is also a good idea to comment your code to document what is happening in your
project. Good practice is to comment what is not obvious.
Start the line with an apostrophe ( ‘ ) or by typing the key word Rem (for remark).
When using an apostrophe to create a comment, you can place the comment at the
end of a line containing a code statement without causing a syntax error.
Defining Objects
Objects are defined by lists of Properties, and Methods. Many also allow for custom
sub-procedures to be executed in response to Events.
The term Class refers to the general structure of an object. The class is a template that
defines the elements that all objects within that class share.
Properties
Properties are the characteristics of an object. The data values assigned to properties
describe a specific instance of an object.
A new Form in Access is an instance of a Form object, created by you, based on the
Form class. Properties that define an instance of a Form object would include its
Name, Caption, Size, etc.
Methods
Printing a report, updating a record and running a query are all examples of actions
that can be executed using a method.
Events
Many objects can recognize and respond to events. For each event the object
recognizes you can write a sub procedure that will execute when the specific event
occurs.
A Form recognizes the Open event. Code inserted into the Open event procedure of
the Form will run whenever the Form is opened.
Events may be initiated by users, other objects, or code statements. Many objects are
designed to respond to multiple events.
The Access Object Module is a set of objects that Access exposes to the development
environment. Many objects are contained within other objects. This indicates a
hierarchy or parent-child relationship between the objects.
The Application object represents the application itself. All other objects are below it
and accessible through it. It is by referencing these objects, in code, that we are able
to control Access.
Objects, their properties and methods are referred to in code using the “dot” operator
as illustrated below:
Parent Object Child Object Method of the Child Object Argument of the Method
The Forms collection in Access represents a set of all open Forms. An item in the
collection can be referenced using an index number or its name.
A large part of programming is referencing the desired object, and then manipulating
the object by changing its properties or using its methods. To reference an object you
need to identify the collection in which it’s contained.
The following syntax references an object in a collection by using its position. Since
the Item property is the default property of a collection there is no need to include it
in the syntax.
                                       Forms(1)
                                      Reports(7)
CollectionName(ObjectName)
Forms(“Employees”)
Reports(“Sales Report”)
The Object Browser is used to examine the hierarchy and contents of the various
classes and modules.
The Object Browser is often the best tool to use when you are searching for
information about an object such as:
Press F2 OR
The following icons and terms are used in the Object Browser:
Method Is a procedure that perform actions (Eg. Copy, Print Out, Delete)
Event Indicates an event which the class generates (Eg Click, Activate)
Most objects in Access have an associated set of properties. During execution, code
can read property values and in some cases, change them as well.
ObjectReference.PropertyName
Form.Name
                      ObjectReference.PropertyName = expression
                           Form.Name = “Quarterly Sales 2006”
The With statement can be used to work with several properties or methods
belonging to a single object without having to type the object reference on each line.
The With statement helps optimize the code because too many “dots” in the code
slows down execution.
  With ObjectName
      <Statement>
  End With
  With recordset
         .movefirst
         .movenext
         .edit
  End With
Many Access objects provide public Sub and Function procedures that are callable
from outside the object using references in your VB code. These procedures are called
methods, a term that describes actions an object can perform.
Some methods require arguments that must be supplied when using the method.
ObjectReference.Method [argument]
Forms(2).Open
Recordset.movelast
When calling procedures or methods that have arguments you have two choices of
how to list the argument values to be sent.
Values can be passed by listing them in the same order as the argument list. This is
known as a Positional Argument.
Alternatively you can pass values by naming each argument together with the value to
pass. This is known as a Named Argument. When using this method it is not
necessary to match the argument order or insert commas as placeholders in the list of
optional arguments
Argumentname:= value
  Sub PrintOut([From],[To],[Copies],[Preview],[ActivePrinter],[PrintToFile],[Collate],
  [PrToFilename])
The statements below show both ways of passing values when calling the PrintOut
method. The first passes by Position, the second by Naming.
Event procedure names are created automatically. They consist of the object, followed
by an underscore and the event name. These names cannot be changed. Event
procedures are stored in the class module associated with the object for which they are
written.
Any programming language relies on its expressions and the statements that put those
expressions to use.
Expressions
Statements are entered one per line and cannot span more than one line unless the
line continuation character ( _ ) is used.
Statements combine the language’s key words with expressions to get things done.
Label(1).Caption = ActiveCell.Value
A variable is name used to represent a value. Variables are good at representing values
likely to change during the procedure. The variable name identifies a unique location
in memory where a value may be stored temporarily.
Naming Variables
To declare a variable you give it a name. Visual Basic associates the name with a
location in memory where the variable is stored.
An Assignment statement is used to set the value of a variable. The variable name is
placed to the left of the equal sign, while the right side of the statement can be any
expression that evaluates to the appropriate data type.
StdCounter = StdCounter + 1
VBA does not require you to explicitly declare your variables. If you don't declare a
variable using the Dim statement, VBA will automatically declare the variable for you
the first time you access the variable. While this may seem like a nice feature, it has
two major drawbacks:
Using Dim, Public, Private and Static declaration statements result in Explicit variable
declarations.
You can force VBA to require explicit declaration be placing the statement Option
Explicit at the very top of your code module, above any procedure declaration.
With this statement in place, a Compiler Error - Variable Not Defined message would
appear when you attempt to run the code, and this makes it clear that you have a
problem. This way you can fix the problem immediately.
Although this forces you to declare variables, there are many advantages. If you have
the wrong spelling for your variable, VBE will tell you. You are always sure that your
variables are considered by VBE.
The best thing to do is tell the VBA Editor to include this statement in every new
module. See Setting Code Editor Options on Page 21.
Important Note
When you declare more than one variable on a single line, each variable must be given
its own type declaration. The declaration for one variable does not affect the type of
any other variable. For example, the declaration:
Dim X, Y, Z As Single
It IS the same as
The choice of data type will impact the programs accuracy, efficiency, memory usage
and its vulnerability to errors.
The structure and size of the memory storage unit that will hold the variable
       The kind and range of values the variable can contain. For example in the
       Integer data type you cannot store other characters or fractions
The operations that can be performed with the variable such as add or subtract.
Important Info
If data type is omitted or the variable is not declared a generic type called Variant is
used as default.
Excessive use of the Variant data type makes the application slow because Variants
consume lots of memory and need greater value and type checks.
Numeric data types provide memory appropriate for storing and working on numbers.
You should select the smallest type that will hold the intended data so as to speed up
execution and conserve memory.
Operations inside parentheses ( ) are performed first. Access evaluates the operators
from left to right.
The following numeric operations are shown in order of precedence and can be used in
with numeric data types.
Divide and Multiply ( / *) Multiply and divide with floating point result
Important Info
For monetary values with up to 4 decimal places use the Currency data type.
Single and Double data types can be affected by small rounding errors.
The keywords used to declare variables, Dim, Static, Public or Private, define the scope
of the variable. The scope of the variable determines which procedures and modules
can reference the variable.
Procedure-Level Variables
These are probably the best known and widely used variables. They are declared (Dim
or Static) inside the Procedure itself. Only the procedure that contains the variable
declaration can use it. As soon as the Procedure finishes, the variable is destroyed.
Module-Level Variables
These are variables that are declared (Dim or Private) outside the Procedure itself in
the Declarations section of a module.
By default, variables declared with the Dim statement in the Declarations section are
scoped as private. However, by preceding the variable with the Private keyword, the
scope is obvious in your code.
All variables declared at this level are available to all Procedures within the Module. Its
value is retained unless the variable is referenced outside its scope, the Workbook
closes or the End Statement is used.
Public Variables
These variables are declared at the top of any standard Public module. Public
variables are available to all procedures in all modules in a project
Public procedures, variables, and constants defined in other than standard or class
modules, such as Form modules or Report modules, are not available to referencing
projects, because these modules are private to the project in which they reside.
     1.   Local (Dim)
     2.   Module-Level (Private, Dim)
     3.   Public (Public)
    Procedure B
    Dim B1
Intrinsic functions appear as methods in the Object Browser. To view and use them:
For further help on a particular function, display the Visual Basic Help window. On the
Contents tab:
A constant is a variable that receives an initial data value that doesn’t change during
the programs execution. They are useful in situations where a value that is hard to
remember appears over and over. The use of constants can make code more readable.
The value of the constant is also set in the declaration statement. Constants are Private
by default, unless the Public keyword is used.
VBA has many built-in constants that can be used in expressions. VBA constants begin
with the letters vb while constants belonging to the Access object library begin with xl.
To access Intrinsic constants in the Object Browser follow the steps below:
The MsgBox Function can be used to display messages on the screen and prompt for
a user’s response.
The MsgBox Function can display a variety of buttons, icons and custom title bar text.
The MsgBox Function can be used to return a constant value that represents the
button clicked by user.
Both MsgBox Functions above produce a message box with 2 buttons, a text
Sub Example()
Dim X As Integer
X=2
MsgBox "The Value of X is " & Str(X)
End Sub
  buttons       Optional. Numeric expression that defines the set of command buttons to
                display, the icon style to use, the identity of the default button, and the
                modality of the message box. Can be specified by entering a vbConstant, the
                actual numeric value of the constant or the sum of constants. If omitted, the
                default value for buttons is 0
  title         Optional. String expression displayed in the title bar of the dialog box. If you
                omit title “Microsoft Access” is the default title
  helpfile      Optional. String expression that identifies the Help file to use for the input
                box. If helpfile is provided, context must also be provided.
  context       Optional. Numeric expression that identifies the appropriate topic in the
                Help file related to the message box
The values and constants for creating buttons are shown below:
The values for controlling the modality of the message box are shown below:
To display the OK and Cancel buttons with the Stop icon and the second button
(Cancel) set as default, the argument would be:
273 (1 + 16 +256).
It is easier to sum the constants than writing the actual values themselves:
When adding numbers or combining constants, for the button argument, select only
one value, from each of the listed groups.
The MsgBox Function returns the value of the button that is clicked. Again this can
be referenced by the number or the corresponding constant.
OK vbOK 1
Cancel vbCancel 2
Abort vbAbort 3
Retry vbRetry 4
Ignore vbIgnore 5
Yes vbYes 6
No vbNo 7
The return value is of no interest when the MsgBox only displays the OK button.
In this case just call the MsgBox Function with the syntax used to call a sub procedure
as shown below:
Or
The InputBox Function prompts the user for a piece of information and returns it as a
string.
In the example the return value of the function is being stored in a variable called
strEmpID.
If OK is clicked, the function returns the contents of the text box or a zero-length
string, if nothing is entered.
If the user clicks Cancel, it returns a zero-length string, which may cause an error in the
procedure if a value is required.
     prompt       Required. String expression displayed in the dialog box. The maximum
                  length of prompt is approximately 1024 characters.
     title        Optional. String expression displayed in the title bar of the dialog box. If
                  you omit title “Microsoft Access is the default title.
     default      Optional. String expression displayed in the text box as the default
                  response. If you omit default, the text box is displayed empty.
     helpfile     Optional. String expression that identifies the Help file to use for the
                  Input box. If helpfile is provided, context must also be provided.
     context      Optional. Numeric expression that identifies the appropriate topic in the
                  Help file related to the Input box
You can also use variables to reference objects in order to work with their properties,
methods and events. Any Access object can be represented and accessed using a
variable name.
Understanding Errors
When developing code, problems will always occur. Wrong use of functions, overflow
and division by zero are some of the things that will cause an error and not produce
the intended results.
Errors are called Bugs. The process of removing bugs is known as Debugging. VBA
provides tools to help see how the code is running.
Syntax Errors
Syntax errors occur when code is entered incorrectly and is typically discovered by the
line editor or the compiler.
       Discovered by Line Editor: When you move off a line of code in the Code
       window, the syntax of the line is checked. If an error is detected the whole line
       turns red by default indicating the line needs to be changed.
       Discovered by Compiler: While the line editor checks one line at a time, the
       compiler checks all the lines in each procedure and all declarations within the
       project. If Option Explicit is set, the compiler also checks that all variables are
       declared and that all objects have references to the correct methods, properties
       and events. The compiler also checks that all required statements are present,
       for example that each If has an End If. When the compiler finds an error it
       displays a message box describing the error.
Run-Time Errors
When a program is running and it encounters a line of code that it cannot be executed,
a run-time error is generated. These errors occur when a certain condition exists. A
condition could run fine 10 times but cause an error on the 11 th. When a run-time
error occurs, execution is halted a message box appears defining the error.
Logic Errors
Logic errors create unexpected outcomes when a procedure is executed. Unlike syntax
or run-time errors the application is not halted and you are not shown the offending
line of code. These errors are more difficult to locate and correct.
Here are a few suggestions to help you minimize or make it easier to find errors in your
code:
Create meaningful variable names. Use prefixes to identify data or object type.
       Any time you use division that contains a variable in the denominator, test the
       denominator to ensure that it doesn’t equal zero
       Keep procedures as short as possible, giving it one or two specific tasks to carry
       out.
       Test procedures with large data sets representing all possible permutations of
       reasonable or unreasonable data. Make your procedure fail before someone
       else does.
VBA’s debugging tools are useful for checking and understanding the cause of logic
and run-time errors in the code.
The toolbar buttons as they appear left to right are explained below:
     Reset                Clears the execution stack and module level variables and
                          resets the project.
     Locals Window        Displays the value of variables and properties during code
                          execution
Debugging is done when the application is suspended (in Break Mode). Everything
loaded into memory remains in memory and can be evaluated. A program enters
Break mode in one of the following ways
While debugging it is useful to find out the value of variables and expressions while
your code is executing.
VBA has the Locals Window, Immediate Window, Watch Window and Quick Watch,
described in Using Debugging Tools on the previous page, which can be used to find
the values of expressions
Another quick way of finding out the value of variables and expressions is the Auto
Data Tip which displays the value of the expression where the mouse is pointing.
Setting Breakpoints
Setting breakpoints allows you to identify the location where you want your program
to enter into break mode. The program runs to the line of code and stops. The code
window displays and the line of code where the break point is set is highlighted.
When the code is halted, the value of a variable or expression can be checked by
holding the mouse pointer over the expression or in the immediate window.
To set a breakpoint open the code window and select the desired procedure:
OR
OR
The step tools allow you to step one line at a time through the code to see exactly
which statements in your procedure are being executed.
During code execution the program can enter into Break Mode either intentionally or
because of a run-time error. When a run-time error occurs a message appears that
describes the error.
      Click the Debug button to display the code window with the offending line
      highlighted.
If during the program execution you need to intervene, for example it’s stuck in an
endless loop, you can do so by pressing Ctrl + Break or the Break button in the
Visual Basic Editor.
That action will suspend the program execution and produce the following message:
Handling errors is another aspect of writing good code. VBA allows you to enter
instructions into a procedure that directs the program in case of an error.
Successfully debugging code is more of an art than a science. The best results come
from writing understandable and maintainable code and using the available debugging
tools. When it comes to successful debugging, there is no substitute for patience,
diligence, and a willingness to test relentlessly, using all the tools at your disposal.
Writing good error handlers is a matter of anticipating problems or conditions that are
beyond your immediate control and that will prevent your code from executing
correctly at run time. Writing a good error handler should be an integral part of the
planning and design of a good procedure. It requires a thorough understanding of
how the procedure works and how the procedure fits into the overall application. And,
writing good procedures is an essential part of building solid Microsoft Office
solutions.
Good error handling should keep the program from terminating when an error occurs.
The error trapping mechanism can be turned on, off or otherwise modified while
developing a project.
For a list of trappable errors in Access search Help for Trappable Errors Constants
while in the Visual Basic Editor.
Use in-line error handling      Use the On Error Resume Next statement to
                                trap the error. Then enter code to check for
                                errors immediately following any statements
                                expected to generate errors.
On Error GoTo 0
This statement disables the error-handling for the procedure at least until another On
Error statement is encountered. This is an alternative to changing the Error Trapping
settings to Break on All Errors as it only affects the procedure it is in. Once the issue
is resolved remove the statement from the procedure.
Error trapping is defined on a procedure-by-procedure basis. VBA does not allow you
to specify a global error trap.
When an error occurs, VBA uses the Err object to store information about that error.
The Err object can only contain information about one error at a time
The properties of the Err object contain information such as the Error Number,
Description, and Source.
The Err object's Raise method is used to generate errors, and its Clear method is used
to remove any existing error information.
Using the Raise methods to force an error can help in error testing routines.
The On Error Go To statement is used to branch to a block of code within the same
procedure which handles errors. This block is known as the error-handling routine and
is identified by a line label.
The routine is always stored at the bottom of the procedure, preceded by an Exit
statement that prevents the routine from being executed unless an error has occurred.
Common line labels used to identify an Error-handling routine are “ErrorHandler” and
“EH”. You can use one of these or create a personal one to handle all your error-
handling routines.
The benefit of using this style is that all the error-handling logic is at the bottom rather
than being mixed up with the main logic of the procedure making the procedure easier
to read and understand.
Sub RunFormula()
  Dim A As Double
  Dim B As Double
MsgBox A / B
Exit Sub
ErrorHandler:
  If Err.Number = 11 Then
     B = InputBox(Err.Description & " is not allowed. Enter a non-zero number.")
     Resume
  Else
     MsgBox "Unexpected Error. Type " & Err.Description
  End If
End Sub
  End Sub / End Function       Used to exit the procedure normally by reaching the
                               End Sub or end Function command
  Exit Sub / Exit Function     Immediately exits the procedure in which it appears.
                               Execution continues with the statement following
                               the statement that called the procedure.
Using this method you place the code to handle errors directly into the body of the
procedure, rather than placing it at the end of the routine.
To do this, place the On Error Resume Next statement into the procedure. The error
handling code is then placed immediately after the line where the code is expected to
cause error. This method may be simpler to use in very long procedures where two or
more errors are anticipated.
Sub ProcFileOpen()
Err.Clear
End Sub
When a procedure runs, the code executes from top to bottom in the order that it
appears. Only the simplest of programs execute in this manner. Most programs
incorporate logic to control which lines of code to execute.
A Boolean expression returns a True or False value. Many Boolean expressions take
the form of two expressions either side of a comparison operator. If the result is true
the condition is met and control is passed to the code to be executed.
Firstname = “Alan”
= Equal to
When testing for more than one condition Boolean expressions can be joined with a
Logical Operator.
If…End If is used to execute one or more statements depending upon a text condition.
There are four forms of the If construct.
The first contains the condition and statement to be executed in the same line:
The block form is used when several statements are to be executed based on result of
the test condition:
                        If <condition> Then
                            <statement block>
                        End If
Like the If…Then structure the If…Then…Else structure passes control to the
statement block that follows the Then keyword when the condition is True and passes
control to the statement block that follows the Else keyword when the condition is
False.
                        If <condition> Then
                            <statement block>
                        Else
                            <statement block>
                        End If
If a true condition is found, the statement block following the condition is performed;
execution then continues with the first line of code following the End If statement. If
no condition is true, execution will continue with the End If statement. An optional
Else clause at the end of the block will catch the cases that do not meet any of the
conditions.
                        If <condition_1> Then
                            <statementBlock1>
                        [ElseIf <condition_2> Then
                            [<StatementBlock2>]]
                        [ElseIf <condition_3> Then
                            [<StatementBlock3>]]
                        [ElseIf <condition_N> Then
                            [<StatementBlockN>]]
                        End If
End If
The Select Case statement is often used in place of the complex If statement. The
advantage of using this style is that your code will be more readable and efficient. The
downside is that it is only useful if compared against just one value.
The Select Case structure contains the test expression in the first line of the block.
Each Case statement in the structure then compares against the test expression.
The syntax of the Select Case structure, followed by two examples is shown below:
The Do…Loop structure controls the repetitive execution of the code based upon a
test of a condition. There are two variations of the structure: Do While and Do Until.
The Do While structure executes the code as long as the condition is true.
The Do Until structure executes the code up to the point where the condition becomes
true or as long as the condition is false. The condition is any expression that can be
evaluated to true or false.
The Exit Do is optional and can be used to quit the Do statement and resume
execution with the statement following the Loop. Multiple Exit Do statements can be
placed anywhere within the Loop construct.
The following syntax is used to perform the statement block zero or more times:
                            Do While <condition>
                               <statement block>
                            [Exit Do]
                            Loop
                            Do Until <condition>
                               <statement block>
                            [Exit Do]
                            Loop
To perform the statement block at least once, use one of the following:
                            Do
                               <statement block>
                            [Exit Do]
                            Loop While <condition>
                            Do
                               <statement block>
                            [Exit Do]
                            Loop Until <condition>
www.MicrosoftTraining.net            0207 987 3777                          75
     Do
        Count = Count +1
     Loop Until Count = NoStudents
The Exit For statement is optional and can be used to quit the For construct and
resume execution with the statement following the Next.
The For Each…Next structure is used primarily to loop through a collection of objects.
With each loop it stores a reference to a given object within the collection to a variable.
The variable can be used by the code to access the object’s properties. By default it
will loop through ALL the objects in a collection.
The Exit For statement is optional and can be used to quit the For Each construct and
resume execution with the statement following the Next.
Use To
Use To
Dialog boxes are used in applications to interface with the user. VBA allows you to
create custom dialog boxes that can display information or retrieve information from
the user as required. These are known as Forms or just Forms.
A Form serves as a container for control objects, such as labels, command buttons,
combo boxes, etc. These controls depend on the kind of functionality you want in the
form. When a new Form is added to the project, the Form window appears with a
blank form, together with a toolbox containing the available controls. Controls are
added by dragging icons from the toolbox to the Form. The new control appears on
the form with 8 handles that can be used to resize the control. The grid dots on the
form help align the controls on the form.
While working on a form the toolbox is displayed but becomes hidden when another
window in the Visual Basic Editor is selected. Controls are added to forms to build a
desired interface and add functionality.
The default set of controls, from left to right, on the above toolbox are described
below:
  Select Objects            Makes the mouse behave as a pointer for selecting a control on a
                            form.
  Combo Box                 Creates the combination of a drop-down list and textbox. The
                            user can select an option or type the choice.
  Option Button             Creates an option button that allows exclusive choice from a set
                            of options.
www.MicrosoftTraining.net            0207 987 3777                                81
     Toggle Button      Creates a toggle button that when selected indicates a Yes, True
                        or On status.
     Tab Strip          Creates a collection of tabs that can be used to display different
                        sets of similar information.
     MultiPage          Creates a collection of pages. Unlike the Tab Strip each page can
                        have a unique layout.
     Scroll Bar         Creates a tool that returns a value of for a different control
                        according to the position of the scroll box on the scroll bar
Every Form has its own set of properties, events and methods. Properties can be set in
both the Properties window and through code in the Code window.
Properties
All forms share the same basic set of properties. Initially every form is the same. As
you change the form visually, in the Form window, you are also changing its properties.
For example if you resize a form window, you change the Height and Width properties.
The following list describes the more commonly used properties of a Form:
Property Description
  MousePointer              Sets the shape of the mouse pointer when the mouse
                            is positioned over the form.
All Forms share a set of events they recognize and to which they respond by executing
a procedure. You create the code to execute for a form event the same way as you
create other event procedures:
Object Procedure
Methods
Forms also share methods that can be used to execute built-in procedures. Methods
are normally used to perform an action in the form.
Use the keyword Me in the Form’s code module instead of its name to refer to the
active form and access its properties and methods.
Control properties can be viewed and assigned manually via the Properties window.
While each type of control is unique many share similar attributes.
The following list contains properties that are common among several controls:
Property Description
  MousePointer          Sets the shape of the mouse pointer when the mouse is
                        positioned over the object
  TabIndex              Determines the order in which the user tabs through the
                        controls on a form.
  Label1 = “Salary”
  Label1.Caption = “Salary”
The following are the more common events that controls can detect and react to:
  Click               Occurs when the user clicks the mouse button while the
                      pointer is on the control
MouseMove Occurs when a user moves the mouse pointer over a control.
Naming Conventions
It’s a good practice to use a prefix that identifies the control type when you assign a
name to the control.
Object Prefix
Frame fra
Image img
Label lbl
Events List
Name Description
Activate             The Activate event occurs when a form receives the focus and becomes the active
                     window.
AfterDelConfirm      The AfterDelConfirm event occurs after the user confirms the deletions and the
                     records are actually deleted or when the deletions are canceled.
AfterFinalRender Occurs after all elements in the specified PivotChart view have been rendered.
AfterLayout          Occurs after all charts in the specfied PivotChart view have been laid out, but
                     before they have been rendered.
AfterRender          Occurs after the object represented by the chartObject argument has been
                     rendered.
AfterUpdate          The AfterUpdate event occurs after changed data in a control or record is
                     updated.
BeforeDelConfirm     The BeforeDelConfirm event occurs after the user deletes to the buffer one or
                     more records, but before Microsoft Access displays a dialog box asking the user to
                     confirm the deletions.
BeforeInsert         The BeforeInsert event occurs when the user types the first character in a new
                     record, but before the record is actually created.
BeforeQuery Occurs when the specified PivotTable view queries its data source.
BeforeRender Occurs before any object in the specified PivotChart view has been rendered.
BeforeUpdate           The BeforeUpdate event occurs before changed data in a control or record is
                       updated.
Click                  The Click event occurs when the user presses and then releases a mouse button
                       over an object.
Close The Close event occurs when a form is closed and removed from the screen.
CommandBeforeExec      Occurs before a specified command is executed. Use this event when you want to
ute                    impose certain restrictions before a particular command is executed.
CommandChecked         Occurs when the specified Microsoft Office Web Component determines whether
                       the specified command is checked.
CommandEnabled         Occurs when the specified Microsoft Office Web Component determines whether
                       the specified command is enabled.
CommandExecute         Occurs after the specified command is executed. Use this event when you want to
                       execute a set of commands after a particular command is executed.
Current                Occurs when the focus moves to a record, making it the current record, or when
                       the form is refreshed or requeried.
DataChange             Occurs when certain properties are changed or when certain methods are executed
                       in the specified PivotTable view.
DataSetChange          Occurs whenever the specified PivotTable view is data-bound and the data set
                       changes — for example, when a filter operation takes place. This event also occurs
                       when initial data is available from the data source.
DblClick               The DblClick event occurs when the user presses and releases the left mouse
                       button twice over an object within the double-click time limit of the system.
Deactivate             The Deactivate event occurs when a form loses the focus to a Table, Query, Form,
                       Report, Macro, or Module window, or to the Database window.
Delete                 Occurs when the user performs some action, such as pressing the DEL key, to
                       delete a record, but before the record is actually deleted.
Dirty The Dirty event occurs when the contents of the specified control changes.
Error                  The Error event occurs when a run-time error is produced in Microsoft Access
                       when a form has the focus.
GotFocus The GotFocus event occurs when the specified object receives the focus.
KeyDown            The KeyDown event occurs when the user presses a key while a form or control
                   has the focus. This event also occurs if you send a keystroke to a form or control by
                   using the SendKeys action in a macro or the SendKeys statement in Visual Basic.
KeyPress           The KeyPress event occurs when the user presses and releases a key or key
                   combination that corresponds to an ANSI code while a form or control has the
                   focus. This event also occurs if you send an ANSI keystroke to a form or control by
                   using the SendKeys action in a macro or the SendKeysstatement in Visual Basic.
KeyUp              The KeyUp event occurs when the user releases a key while a form or control has
                   the focus. This event also occurs if you send a keystroke to a form or control by
                   using the SendKeys action in a macro or the SendKeys statement in Visual Basic.
Load Occurs when a form is opened and its records are displayed.
LostFocus The LostFocus event occurs when the specified object loses the focus.
MouseDown The MouseDown event occurs when the user presses a mouse button.
MouseMove The MouseMove event occurs when the user moves the mouse.
MouseUp The MouseUp event occurs when the user releases a mouse button.
MouseWheel         Occurs when the user rolls the mouse wheel in Form View, Split Form View,
                   Datasheet View, Layout View, PivotChart View, or PivotTable View.
OnConnect Occurs when the specified PivotTable view connects to a data source.
OnDisconnect Occurs when the specified PivotTable view disconnects from a data source.
Open               The Open event occurs when a form is opened, but before the first record is
                   displayed.
PivotTableChange   Occurs whenever the specified PivotTable view field, field set, or total is added or
                   deleted.
Query              Occurs whenever the specified PivotTable view query becomes necessary. The
                   query may not occur immediately; it may be delayed until the new data is
                   displayed.
Resize The Resize event occurs when a form is opened and whenever the size of a form
SelectionChange        Occurs whenever the user makes a new selection in a PivotChart view or PivotTable
                       view.
Timer                  The Timer event occurs for a form at regular intervals as specified by the
                       form's TimerInterval property.
Unload                 The Unload event occurs after a form is closed but before it's removed from the
                       screen. When the form is reloaded, Microsoft Access redisplays the form and
                       reinitializes the contents of all its controls.
ViewChange Occurs whenever the specified PivotChart view or PivotTable view is redrawn.
Each control has a set of properties that can be set in the design environment using
the Properties window. Categories for the property window vary per object.
The Label control is used to display text on a form that cannot be modified by the user.
Property Description
The Text Box control allows the user to add or edit text. Both string and numeric
values can be stored in the Text property of the control.
Property Description
Command buttons are used to get feedback from the user. Command buttons are
among the most important controls for initiating event procedures.
The most used event associated with the Command Button is the Click event.
Property Description
     Cancel          Allows the Esc key to “click” a command button. This property
                     can only be set for one command button per form.
The Combo Box control allows you to display a list of items in a drop-down list box.
The user can select a choice from the list or type an entry.
The items displayed on the list can be added in code using the AddItem method.
Property Description
ListRows Sets the number of rows that will display in the list.
     MatchRequired      Determines whether the user can enter a value that is not on
                        the list.
Text Returns or sets the text of the selected row on the list.
Some important methods that belong to the Combo Box are explained below:
     AddItem item_name, index       Adds the specific item to the bottom of the list.
                                    If the index number is specified after the item
                                    name its added to that position on the table
The Frame control is used to group a set of controls either functionally or logically
within an area of a Form. Buttons placed within a frame are usually related logically so
setting the value of one affects the values of others in the group.
Option buttons is a frame are mutually exclusive, which means when one is set to
true the others will be set to false.
An Option Button control displays a button that can be set to on or off. Option
buttons are typically presented within a group in which one button may be selected at
a time.
The Value property of the button indicates the on and off state.
The Form toolbar provides several tools that are used to manipulate the appearance of
the controls on the form.
Many of the tools on the Form toolbar require the user to select multiple controls. To
do this:
Controls will be aligned or sized according to the first control selected. The first
control selected is identified by its white selection handles.
The tab order is the order by which pressing the Tab key moves focus from control to
control on the form. While the form is being built the tab order is determined by the
order in which you place the controls on the form. If the controls are rearranged you
may nee to manually reset the tab order. To set the tab order:
A list box or combo box control placed on the form is not functional until the data that
will appear on the list is added.
This is done by writing code in the sub procedure associated with the Initialize event.
This triggers when the form is loaded. The AddItem method is used to specify the text
that appears in the list.
The code below shows items added to a combo box named cboCourses:
                       With cboCourses
                          .AddItem “Excel”
                          .AddItem “Word”
                          .AddItem “PowerPoint”
                       End With
As seen, forms and their controls are capable of responding to various events. Adding
code to forms and control events are accomplished the same way as adding code to
events of other objects.
The Show method of the form object is used to launch a form within a procedure.
Creating a procedure to launch a form enables you to launch a form from a toolbar, or
menu as well as from an event such as opening a workbook.
FormName.Show
frmNewData.Show
VBA is the programming language you use to interact with the Access Object Model.
To interact with the data in a database, you will need to use a data access object
model.
Access employs two such object models; Data Access Objects and ActiveX Data
Objects.
DAO allows you to work with and manipulate the records in table and queries within an
access database
Critical objects
Object                Use
Database              It is necessary to define the database that you are working with.
We are primarily concerned with manipulating existing data. For this we are primarily
concerned with using the Recordset object
Tasks                                             Description
Opening                                           Dbs.OpenRecordset(“Table1”,
                                                  dbOpenTable)
Critical objects
Object             Use
Database           It is necessary to define the connection that you are working
Connection         with also if it is the current database
Dim CN as ADODB.Connection
Set cn = CurrentProject.Connection
Dim rs as ADODB.Recordset
                   strSql = "select * from tblImport" (SQL string all records from the
                   table tblImport)
and now you can open the recordset based on the SQL string
Tasks                                       Description
Moving through a recordset                  MoveFirst              Moves to first
                                                                   record
                                            MoveLast               Moves to last
                                                                   record
                                            MoveNext               Move to next
                                                                   record
                                            MovePrevious           Move to previous
                                                                   record
Editing a recordset                         Edit                   Prepares a record
                                                                   for editing
                                            Update                 Commits the
                                                                   changes made to a
                                                                   record
Adding to a recordset                       Append                 Adds new data as a
                                                                   new record
Dim cn As ADODB.Connection
Dim rs As ADODB.recordset
Dim strSql As String
Set cn = CurrentProject.Connection
Set rs = New ADODB.recordset
rs.MoveFirst
Do Until rs.EOF
rs.MoveNext
Loop
rs.Close
Set rs = Nothing
End Sub
Sub ChangeProductPrices()
Dim rs As ADODB.recordset
Dim sSQL As String
Dim sValue As String
Dim cn As ADODB.Connection
Set cn = CurrentProject.Connection
DoCmd.SetWarnings False
rs.MoveFirst
Do Until rs.EOF
If rs.Fields("product description") Like "shoe*" Then
rs.Fields("unit price") = rs.Fields("unit price") * 1.07
ElseIf rs.Fields("product description") Like "boots*" Then
rs.Fields("unit price") = rs.Fields("unit price") * 1.1
ElseIf rs.Fields("product description") Like "ball*" Then
rs.Fields("unit price") = rs.Fields("unit price") * 1.09
ElseIf rs.Fields("product description") Like "*fishing" Then
rs.Fields("unit price") = rs.Fields("unit price") * 1.09
End If
rs.MoveNext
Loop
DoCmd.SetWarnings True
rs.Close
End Sub
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
_____________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
_____________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
____________________________________________________________________________________________
_____________________________________________________________________