Visual Basic is the programming language for Microsoft Access. You use it for the same reason you use macros—to tie the objects in your application together into a coherent system. The difference is that Visual Basic provides more power and a finer degree of control than you get by using macros alone.
Visual Basic is a modern programming language that strongly resembles most of the popular, structured programming languages. If you’re a Pascal or C programmer, you’ll find all the program structures you’re used to—loops, If...Then...Else statements, Select Case statements, functions, and subroutines—with only superficial differences. With all its improvements from earlier versions of Basic, Visual Basic retains its English-like flavor and ease of use.
With Microsoft Access, you can accomplish many tasks with macros or through the user interface that require programming in other database systems. So, when do you turn to Visual Basic? It depends on what you want to do.
You’ll want to use Visual Basic instead of macros if you want to do any of the following:
See Also For more information on creating a function, see “Creating Your First Function” later in this chapter.
See Also For more information on handling errors in your application, see Chapter 8, “Handling Run-Time Errors.”
Tip Although you can have both macros and Visual Basic code in your application, you may find it easier to use Visual Basic exclusively once you get started programming. If you have macros in your application, Microsoft Access can automatically convert them to event procedures or modules that perform all the equivalent actions in Visual Basic code.
In form or report Design view, use the Convert Macros To Visual Basic command (Tools menu, Macro submenu). For global macros that aren’t attached to a specific form or report, use the Save As/Export command (File menu) to save the macro as a module. For more information, search the Help index for “macros, converting.”
After reading all the reasons for using Visual Basic, you may wonder if there are any reasons left for using macros. However, macros do have their place in many applications. Macros are an easy way to take care of simple details such as opening and closing forms, showing and hiding toolbars, and running reports. Because you specify options for each action in the lower part of the Macro window, there’s little syntax to remember, and developing applications can often be faster than with Visual Basic.
In addition to the ease of use macros provide, creating a macro is the only way to make global key assignments.
See Also For information on assigning keys with an AutoKeys macro, see Chapter 1, “Creating an Application.”
An event is an action recognized by a form, report, or control. Each type of object in Microsoft Access automatically recognizes a predefined set of events. When you want a form, report, or control to respond to an event in a particular way, you can write a Visual Basic event procedure for that event.
Here’s what happens in a typical event-driven application:
Note Some events automatically trigger other events. For example, when the MouseDown event occurs, the MouseUp and Click events immediately follow.
In a traditional procedural program, the application rather than an event controls the portions of code that are run. It begins with the first line of code and follows a defined pathway through the application, calling procedures as needed.
In event-driven applications, a user action or system event runs an event procedure. Thus, the order in which your code is run depends on the order in which events occur; the order in which events occur is determined by the user’s actions. This is the essence of graphical user interfaces and event-driven programming: The user is in charge, and your code responds accordingly.
Because you can’t predict what the user will do, your code must make a few assumptions about “the state of the world” when it runs. It is important that you either test these assumptions before running your code or try to structure your application so that the assumptions are always valid. For example, if your application assumes that a text box has text in it before the user clicks a command button, you can write code to enable the command button only when the Change event for the text box occurs.
See Also For information on events, see Chapter 6, “Responding to Events.”