Learn Microsoft Access Advanced Programming Techniques, Tips and Tricks.

Sunday, August 31, 2008

Access Live Data in Excel-2


Continued from last week's post
:

This is a continuation of the earlier post Access Live Data in Excel. Please refer to the earlier article before continuing.

If you want to make changes to the Query that you have created for bringing Access Data into Excel, you may do so.

  1. Click on a cell within the Data Area on the Worksheet.

  2. Point to Import External Data (Get External Data in MS-Office 2000) in the Data Menu.

  3. Select Edit Query from the displayed menu. The Wizard will guide you through the earlier selections, and you can modify them before saving the Query.

Microsoft Query.

Alternatively, you can open the Microsoft Query Program (C:\Program Files\Microsoft Office\Office11\MSQRY32.EXE in MS-Access 2003) and open the saved Query (Refer earlier Post Access Live Data in Excel for Query File's default location) from the File Menu, edit the SQL String, and view the Output data in the Query Editor before saving the changes.

When you open the Query that you have created and saved earlier, the Source Data will be displayed in Datasheet View. Click on the SQL-labeled Toolbar Button or select SQL from the View menu.

You will find the SQL String like the sample given below:

SELECT Categories.CategoryID,
 Categories.CategoryName,
 Categories.Description,
 Categories.Picture
FROM `C:\Program Files\Microsoft Office\Office11\samples\Northwind`.Categories Categories

The normal SQL terminator character semicolon (;) is not present. The FROM Clause in the SQL is written differently without the use of an IN Clause, which we have seen in the MS-Access Query to Open Excel or dBase Tables directly using the Source Connect Str Property. The Categories Table Name is attached to the sample Database Path Name with a dot separator, and the Table Name is repeated with a space in between. The .mdb file extension for Northwind is also omitted from the database file name specification.

If you copy and paste the above SQL String into an MS Access Query and change it to Datasheet View, it will display the data correctly. No errors will be displayed, except some Column headings may appear as Expr3, Expr4, and so on, if you have changed the Query in Design View first and then switched into Datasheet View.

Properties of Microsoft Query

This is the time to learn the usage of two more Properties of MS-Access Query.

  1. Copy the above SQL String into a new MS-Access Query SQL window.

  2. Select View -> Datasheet View to display Records from the Categories Table from the Northwind.mdb database.

  3. Select View -> Design View to change the Query Design View.

  4. The Table Object has already been visible on the Query Design surface, but the Field Names are absent. Click on the title area of the Table to select it.

  5. Display the Property Sheet (View -> Properties. The Alias and Source Properties of the Query are displayed.

  6. The Table Name Categories are loaded in the Alias Property, and the Path Name of the NorthWind database appears in the Source Property without the .mdb extension.

  7. Change the Table Name appearing in the Alias Property to a different name, say myCategories.

  8. Add .mdb extension at the end of the Pathname string in the Source Property.

The Table Name now appears as myCategories in the Title of the Table. Turn the Query into an SQL View. You can see that at the end of the SQL String, the reference to the Table name, Categories (which appeared twice earlier), has now changed to myCategories.

We must qualify each data field with the Table Name myCategories due to the Alias Name change. Change the SQL String as shown below to qualify each Field with the Alias Name. Enclose the Database Path Name in Square Brackets ([]) in place of the single quotes.

SELECT [myCategories].[CategoryID],
 [myCategories].[CategoryName],
 [myCategories].Description,
 [myCategories].Picture
FROM [d:\Program Files\Microsoft Office\Office\samples\Northwind.mdb].Categories AS myCategories;

The manual change is necessary because we are referencing an external data source, and no way MS-Access can guess the name. If we are using a Table from within the Database or from a linked Table, then the Alias Name change will automatically take effect in all the fields. You can try this experiment with one of your own Tables from within the Database or with a linked Table.

Note: The Source Database and Source Connect Str Property Values are taken into the Query Syntax with an IN Clause to identify the external Application.

Alias Property is initially set with the Table Name and accepts changes to the Table Name through this Property.

Source Property accepts the external Database reference, either a direct Path Name or an ODBC Connection String, and the SQL Syntax is different in the FROM Clause of the Query definition.

Earlier Post Link References:

  1. Roundup Function in Excel in MS-Access
  2. Proper Function in Excel in Microsoft Access
  3. Appending Data from Excel to Access
  4. Writing Excel Data Directly into Access
  5. Printing MS-Access Report from Excel
  6. Copy-Paste Data From Excel to Access 2007
  7. Microsoft Excel-Power in MS-Access
  8. Rounding Function MROUND of Excel
  9. MS-Access Live Data in Excel
  10. Access Live Data in Excel- 2
  11. Opening an Excel Database Directly
  12. Create Excel, Word files from Access

Friday, August 22, 2008

MS-Access Live Data in Excel


Introduction.

We have already explored several techniques for accessing and working with external data sources—such as Access tables, dBase files, and Excel worksheets—without permanently linking them. These included both VBA-based and query-based approaches.

However, we have not yet experimented with using an ODBC connection string in the SourceConnectStr property of a query to open external data files. While linking external data to Access manually is straightforward, we will later explore how to perform this linking dynamically through VBA.

Before diving into that, let’s look at something slightly different—a reversal of the usual “one-way traffic” of data flow from external sources into Access. Interestingly, the data flow isn’t truly one-way: we can also update external data directly from Access, whether or not those data sources are permanently linked.

When we use queries configured with SourceDatabase and SourceConnectStr properties to open external data, the resulting datasets are fully updatable. Any changes made to these records within Access are automatically reflected in their original parent applications.

Live MS-Access Data in an Excel Sheet

In this section, we will explore how to link live Microsoft Access data into Excel so that any updates made in Access are automatically reflected in Excel. In this setup, Access functions as the server application, while Excel acts as the client.

There is, however, one important distinction from our earlier methods: although you can edit the linked data in Excel, those changes will not be written back to Access.

So, what’s the purpose of having Access data in Excel? You can use it to create charts, perform calculations, or prepare analytical reports—especially if you’re more comfortable working in Excel. You can also create links (using Copy → Paste Special → Paste Link) to reference this live data in other parts of the workbook. This way, any updates in Access will automatically appear in your reports or charts within Excel, ensuring your information always stays current.

To bring Access data into Excel, we use Microsoft Query, which serves as the intermediary between the two applications. The Query Wizard will guide us through the necessary steps to connect Excel with the Access database.

For our example, we’ll use the Categories table from the Northwind.mdb sample database.

Step through the following procedure.

  1. Open a new MS-Excel Workbook.

  2. Select Cell A1 on Sheet1.

  3. Point to Import External Data in the Data Menu.

  4. Select New Database Query from the displayed menu.

    Now, the Microsoft Query Wizard opens up and displays a Dialog Box. It displays the Database Sources list in the Databases tab, which you can link to MS-Excel. This is a combined list of items appearing in the ODBC Dialog Control User DSN, System DSN, and File DSN Tabs.

  5. Select the MS-Access Database* from the list and click OK.

  6. The Common Dialog Control opens up, allowing you to browse to the Location of the MS-Access Database and select it. Find the sample database C:\Program Files\Microsoft Office\Office11\Sample\Northwind.mdb (MS-Access 2003, you can drop 11 from Office11 in the location address for Access 2000), select and click OK.

  7. Select the Categories Table from the Available Tables and Columns in the Query Wizard and click on the > symbol to select all the Fields of the Categories Table into the Columns in your Query Control. If you don't need all the fields from the Source Table, then expand the Categories Table by clicking on the + symbol to display all the Fields and select only those you need and move them to the right side panel.

    Before you move the field to the right, you can preview the Field contents by clicking the Preview Now button below. Memo Field or OLE Object field contents cannot be previewed this way.

  8. After selecting the Fields, click Next. Here, you can define Filter conditions.

  9. Click Next to proceed to the Sort options.

  10. Click Next to move to the Finishing point.

    Here, we have the option to save the selected settings in a Microsoft Query (which is an external File) at the location C:\Documents and Settings\User\Application Data\Microsoft Queries\. If we need any changes in the data selection options, then we can open this saved file in Microsoft Query and edit the Query Definition in SQL Window.

  11. See the Radio Button set on Return Data in Microsoft Office Excel and click Finish.

  12. In the next Dialog Control, you can select the Location on the Excel Sheet where you want to insert the data from Access. Since we have already selected Cell A1 as the target location in Step 2 above, this will appear as the default location in the control; click OK without change.

The records from the Categories Table will be inserted in Excel, starting from the range address A1.

It was a long journey from Access to Excel. Bringing Excel data into Access needs only two property changes in MS-Access Query, and now you know how simple it is.

Refreshing Updates from Access Table.

Now that we have successfully brought Access data into Excel, let’s perform a few simple experiments to confirm that it is indeed live data—directly linked to the Access database. We’ll also observe how any changes made in Access are automatically reflected in Excel, demonstrating the dynamic connection between the two applications.

There are two methods to refresh Access Data in Excel: Manual and Automatic.

Keep the Northwind.mdb sample database open so that we can make changes in the linked table in Excel or in Access and check the results of the change in both Applications.

  1. Open the Categories Table of the Northwind.mdb Database.

  2. Add Crabs and Lobsters in the Description field of the last record. Or add a new record with some Category Name and Description.

  3. Minimize MS-Access and display the Excel Window, and check whether the change has taken place immediately in the linked data in Excel. You may not find any change on the Excel side. We have to refresh the data in Excel to reflect the changes.

  4. Click anywhere within the data Area.

  5. Select Refresh Data from the Data Menu.

    Now, any changes you make in Access will be automatically updated on the Excel side as well. Moreover, you can configure Excel to refresh the linked data automatically at regular intervals, eliminating the need to perform manual updates.

  6. Right-click anywhere within the linked table in Excel and select Data Range Properties from the shortcut menu.

  7. In the dialog box that appears, you will find several options to manage the linked data, including the name of the query that retrieves data from Access into Excel. Under the Refresh Control section, select the Refresh every option and set the interval to 1 minute. This allows you to observe the automatic refresh in action without waiting too long.

  8. Next, switch to the Access window and either undo the earlier changes made to the Categories table or make new edits that will be easily noticeable in Excel once the data refreshes.

  9. Return to Excel and wait for the refresh to occur. You should soon see the updates reflected in the worksheet—Excel will continue to refresh the data automatically at one-minute intervals.

If you have made any changes to the data on the Excel side, those modifications will be lost during the refresh process.

When you close and reopen the Excel workbook, a prompt will appear asking whether Excel should automatically refresh the linked data. You can choose to enable or disable this feature according to your preference.

Friday, August 15, 2008

Database Connection String Properties

Introduction.

Opening external data sources such as dBase files, Excel sheets, or tables from another MS Access database directly through VBA code is just one of the available options. For those who are not comfortable working with VBA, a better alternative allows you to access external data without permanently linking it to your Access database.

In either approach, one thing remains essential: you must know how to correctly reference different external data sources using the appropriate Source Database Path and Connection String values. Fortunately, these methods are quite straightforward to learn.

While understanding the syntax for ODBC (Open Database Connectivity) connection strings can be slightly challenging, there are some helpful shortcut techniques to determine them. However, we will set aside the ODBC discussion for now and revisit it later with a relevant example.

As demonstrated earlier, we can display values from Excel cells or ranges directly on MS Access form controls.

In the previous examples on opening Access tables, dBase tables, and Excel tables directly through VBA, you may have considered copying the SQL strings from the VBA code into queries and testing them there. If you haven’t done so yet, now is a good time to try—it’s a great way to understand how they work and to explore a few important details about their usage.

Open Recordset in Select Query, from External Access Database

Let us try to open an MS-Access Table from another Database directly in a Select Query.

  1. Open one of your Databases or create a new one.

  2. Select the Query Tab and Click the New Button on the Database Menu. Select the Design View from the displayed Options and click Close without selecting any Table from the list.

  3. Click on the SQL Toolbar Button or select SQL View from the View Menu.

  4. Copy and Paste the following SQL String in the SQL Editing Window, and Save the Query with the Name EmployeesQ.

    SELECT Employees.* 
    FROM Employees IN 'C:\Program Files\MicrosoftOffice\Office\samples\Northwind.mdb';

    Note: If you are using MS-Access 2003, then change the Path to . . .\Office11\Samples\.

  5. Open the Query in Datasheet View (View -> Datasheet View) to display the Employees Table contents from the Sample Database Northwind.mdb.

In the SQL String, an IN Clause is used for pointing to the correct database path, and the entire Path Name is put in quotes and ends with a semi-colon, indicating the end of the SQL String, which is applicable for all Queries.

A Different and Simple Method

There’s another way to accomplish this. The first part of the statement can be written directly in the SQL window, while the IN clause can be added separately in the Source Database and Source Connection String properties of the query. This approach eliminates the need to remember where to place the word IN, or where to insert opening and closing quotation marks, freeing you from such syntax concerns.

  1. Create a New Query and open the SQL editing window following Steps 1 to 3 explained above.

  2. Write the SQL string SELECT Employees.* FROM Employees;

  3. Select Design View from the View Menu to change the Query from SQL View in Design View. We are now in the normal Query Design View. You will find the Employees Table object appearing in the Query Design without any Field Names showing in it.

  4. Select Properties from the View Menu to display the Property Sheet of the Query.

  5. Click on an empty area of the Query surface, to the right of the Table Name, to display the Query level Property Sheet correctly.

  6. There are two properties on the Property Sheet that we are interested in.

    • Source Database
    • Source Connect Str

    Here, we will be using only the Source Database Property for the external MS Access Table.

  7. Enter the following Path Name in the Source Database Property, overwriting the text (current).

    C:\Program Files\Microsoft Office\Office\samples\Northwind.mdb

    Or with the change explained above for MS-Access 2003 cases.

  8. Select Datasheet View from the View Menu.

You will now see the same result as the first Select Query we tried. If you change the Query into its SQL View and inspect the SQL String, you can see that the IN Clause is formed using the Source Database property Value.

Source Connect Str for dBase and Excel

You can use the same method for a dBase Table and an Excel Table (Named Range). In these cases, we need to use the Source Connect Str Property.

Example: opening the dBase Table directly.

Table Name: Customer.dbf

SQL String: SELECT Customer.* FROM Customer;

Source Database Property Value = C:\mydBase

Source Connect Str Property Value = DBASE IV; (check the semicolon at the end)

Replace the Customer table name and the Path C:\mydBase location address with your own dBase File Name and Folder name, where the dBase Table is located.

Example: opening an Excel Table (Named Range) directly.

Table Name: Categories

SQL String: SELECT Categories.* FROM Categories;

Source Database Property Value = C:\My Documents\Products.xls

Source Connect Str Property Value = Excel 5.0;

(note the semicolon at the end)

Replace the Categories table name and the Path C:\My Documents\Products.xls Excel file with your own.

NB: You must first define the Name Categories in the Excel Table Range using Insert -> Name -> Define before attempting to use the Name Categories in MS-Access Queries.

Next: MS-Access Live data in Excel

Earlier Post Link References:

Friday, August 8, 2008

Opening Excel Database directly

Introduction

In the world of Personal Computers, many applications emerged and disappeared. One of the very popular applications was WordStar (Word Processor), used under Operating Systems CP/M-80 (Control Program for Microcomputers) and MS-DOS (Disk Operating System) till 1992. There were dedicated Word Processing Machines in those days, using WordStar and competing Software WordPerfect

The first spreadsheet program, VisiCalc, was released in 1979 and made a groundbreaking impact. It soon inspired several successors—SuperCalc, Multiplan, Lotus 1-2-3 (1983), and eventually Microsoft Excel (1985)—each adding more power and functionality than the original VisiCalc. (Source: Wikipedia)

Like Microsoft Access, Microsoft Excel also includes powerful automation capabilities that make spreadsheet-based computing both flexible and engaging.

Spreadsheet programs are designed for analytical tasks that involve a chain of calculations, with all relevant data visible on the sheet. A small change made at the beginning of a calculation can trigger a cascading effect through dependent cells, instantly updating the final results. This makes Excel an invaluable tool for “what-if” analysis. And when it comes to creating graphical charts, Microsoft Excel remains the first name that comes to mind.

Excel Table

Although Excel includes limited database-like features, such as built-in functions, filters, and sorting capabilities, it can still be used effectively for structured data management. This brings us to our next example—creating a table in Excel that can be read from or updated by Microsoft Access.

While Excel provides the tools needed to follow general database principles when creating and maintaining a table, these rules are often overlooked. Users are free to design their worksheets in any manner, even mixing regular data and database-like tables side by side on the same sheet.

In contrast, Access enforces strict data integrity rules—for example, text cannot be entered into numeric fields, field names must be unique, and data cannot exceed defined field sizes. The same principles technically apply in Excel, but violations often go unnoticed because Excel doesn’t always flag them. As a result, the worksheet may not function as intended when used as a data source.

Moreover, not all Access data types exist in Excel—for instance, the True/False field type in Access has no direct equivalent, although Boolean values like TRUE and FALSE are still valid entries in Excel cells.

Before we create a database-style table in Excel and open it directly in Access (as we did with a dBase file), let’s explore how to set data validation rules in Excel to restrict cell entries. You may be surprised by how powerful these validation features can be.

Validation Settings.

Example: Accept only values between 25 and 100 in a Cell or Cells.

  1. Open Excel and select a Cell in Sheet1.

  2. Select Data -> Validation ...  -> Settings.

  3. Select Whole Number in the Allow control.

  4. Enter 25 in the Minimum Control and 100 in the Maximum Control.

  5. Select the Input Message Tab. Enter Age in the Title Control and type Enter Value between 25 and 100 in the Input Message.

  6. Select the Error Alert Tab and type Value Error in the Title Control.

  7. Type Valid Value between 25 and 100 in the Error Message Control and click OK to close it.

Try entering a value less than 25 or greater than 100 in this cell, and it will display the Error message that you have set up in the Validation Control.

You can apply the same rules quickly to other cells. Copy the Cell, highlight the Range of Target Cells, and select Edit -> Paste Special -> Validation. If you paste it over existing data, it will not validate the field contents if the wrong value is already present in the Cell. The validation check is performed only when you manually key in values.

Following the same procedure, try setting a validation rule in a Cell to accept only Text Length is Less Than 15 characters. Try entering 16 characters or more into that Cell.

When planning to create a database in Excel, begin by defining short, meaningful headings in the top row—these will serve as your field names. Next, apply data entry rules (as explained earlier) to each column so that only valid values can be entered. Excel also provides a built-in Data Entry and Search Form, similar to the one available in Microsoft Access.

If you already have a data table in Excel, simply click anywhere within the table and select Form from the Data menu. This will open a Data Entry/Search Form. By clicking the Criteria button, you can switch it into search mode, where you can enter specific criteria in any field to locate a record.

You can experiment with this feature after we create an Excel table, which we’ll later open directly in MS Access through a VBA program.

Preparing for a Trial Run.

  1. Open Microsoft Excel (if it is already closed).

  2. Open the NorthWind.mdb sample database. Check the link Saving Data on Forms not in Table for location references, if you don't know where this file can be found.

  3. Open the Categories Table in Datasheet View.

  4. Right-click on the top left corner of the Datasheet View and select Copy from the shortcut menu.

  5. Click on the Excel Icon on the Taskbar to open it and select Cell A1.

  6. Select Paste from the Edit Menu.

  7. While the highlighting is still on the pasted Table, select Insert -> Name -> Define and type Categories in the Names in Workbook control, click the OK button to close it.

  8. Save the Workbook with the name: C:\My Documents\myData.Xls, and close Microsoft Excel and close the Northwind.mdb sample Database.

  9. Open any one of your Databases or create a new one.

  10. Copy and paste the following code into the Global VBA Code Module of your Database and keep the Module open. You may save the Module by selecting the Save Toolbar Button or with the File -> Save option.

    Public Sub OpenDirectExcel()
    '-----------------------------------------------------
    'Open Excel Table directly
    'Author : a.p.r. pillai
    'URL    : www.msaccesstips.com
    'All Rights(c) Reserved by msaccesstips.com
    '-----------------------------------------------------
    Dim db As Database, rst As Recordset
    Dim strSql As String, i As Integer
    Dim msg As String
    
    strSql = "SELECT Categories.* FROM Categories IN 'C:\My Documents\myData.xls'[Excel 5.0;];"
    Set db = CurrentDb
    Set rst = db.OpenRecordset(strSql, dbOpenDynaset)
    
    i = 0
    With rst 
    msg = ""
    Do While Not .EOF And i < 5
       msg = msg & ![Category Name] & vbCr
       If ![Category Name] = "Confections" Then
          .Edit
          ![Category Name] = "Chocolates"
          .Update
       End If
       i = i + 1
       .MoveNext
    Loop
    .Close
    End With
    
    MsgBox msg, , "Product Categories"
    
    Set rst = Nothing
    Set db = Nothing
    
    End Sub
    
  11. Click in the middle of the Code and press F5 to run it. Displays the Product Category Names of the first five Records from the Categories Table in C:\My Documents\myData.xls in a Message Box.

Note: In the VBA Code, we have tested the Category Names Field for the value Confectionaries, and updated the Value Chocolates back into the Excel Cell, overwriting the word Confectionaries.

Check the SQL Syntax in the Code that pulls the data directly from the Named Range Categories in C:\My Documents\myData.xls file.

  1. Microsoft Excel and Automation
  2. Microsoft Excel and Automation-2

Next: Database Connection String Properties

Earlier Post Link References:

  1. Roundup Function
    of Excel in MS-Access
  2. Proper Function of Excel in Microsoft Access
  3. Appending Data from Excel to Access
  4. Writing Excel Data Directly into Access
  5. Printing MS-Access Report from Excel
  6. Copy-Paste Data From Excel to Access 2007
  7. Microsoft Excel Power in MS-Access
  8. Rounding Function MROUND of Excel
  9. MS-Access Live Data in Excel
  10. Access Live Data in Excel- 2
  11. Opening an Excel Database Directly
  12. Create an Excel Word File from Access

Friday, August 1, 2008

Display Excel Value Directly on Form

Introduction - MS Access 2003

In the earlier post, Opening dBase Files Directly, we learned how to open and work with dBase files in MS Access using VBA. However, there are several alternative methods—other than linking—to handle dBase files within Access. We’ll explore those options in detail later.

This post, however, was originally meant to demonstrate how to open an Excel-based data table directly and work with it in VBA. We’ll cover that in the next section. But before diving into that, let’s take a short detour to try out some simple yet fascinating Excel tricks.

I say “simple” because you won’t need to wrestle with any complex VBA code this time. And I know you’ll appreciate that little break from my so-called spaghetti code!

As the title suggests, we’re going to explore how to display values from an Excel worksheet directly on Microsoft Access forms—no heavy coding required.

The Demo Run Preparation

  1. Open Microsoft Excel.

  2. Enter your name in cell A1 on Sheet1, then minimize Excel—but don’t close it. You may save the workbook with a suitable name. Keep in mind that if the AutoSave feature is turned on, Excel may prompt you to save your changes.

  3. Open any one of your Microsoft Access Databases or create a new one.

  4. Open a New Form in Design View.

  5. Select the Text Box Tool from the Toolbox and draw a Text Box on the Detail Section of the Form.

  6. Click on the Text Box and display the Property Sheet (View -> Properties).

  7. Write the following expression in the Control Source Property of the Text Box:

    =DDE("Excel","Sheet1","R1C1")

  8. Save the Form with the name of your choice.

  9. Open the Form in Normal View. You will see your Name written on an Excel Cell appearing in the Text Box on the Form.

    The DDE() Function stands for Dynamic Data Exchange. The first two Parameters are the Excel Application and the worksheet name Sheet1, and the third one is the Cell Reference where your name is written in R1C1 (Row-1 Column-1 or Cell A1). Cell reference must be used in this way rather than the A1 style.

    Do the following, if not successful.

    But, you may end up with nothing showing in the TextBox. In that case, you have to see if a particular Option is set correctly on the General Tab of Options in the Excel Tools Menu.

  10. Click on the Excel icon on the Taskbar to open it. Click on Tools -> Options, and select the General Tab.

  11. Remove the check mark (if it is set) from the Ignore Other Applications option in the Settings Options.

  12. Minimize Excel, close the MS Access Form, and open it again. Now you must see your name in the Excel Cell on the Form. Don't close the Form.

  13. Maximize Excel, make some changes to the Name, and minimize again. The change may not reflect immediately on the Form. You can update the Form value manually without the closing and opening steps.

  14. While the Access Form is in Normal View, select OLE/DDE Links from the Edit Menu.

  15. The Links Dialog Box will open up. Select DDE Links in the Links Group control. The Link's list will appear below. Select the Link and click on the Update Now Command Button. Now the change on the Worksheet will reflect the Form Value.

Microsoft Access also includes option settings similar to those in Excel. Generally, instead of manually refreshing changes—as we did earlier—the updates should occur automatically at fixed intervals according to the settings under Tools → Options in Microsoft Access. However, in my experience, this feature hasn’t worked reliably on my system so far.

Select Tools → Options → Advanced tab. Ensure that the Enable DDE Refresh option is checked if it is not already enabled. In this section, you can also view the default settings for automatic refreshing of Dynamic Data Exchange (DDE) and ODBC links — including the number of retry attempts and the wait time before Microsoft Access tries again in case of a failure.

Display Value in Combo Box and Option Group

You can display Values from Excel in two more Access Controls, Combo Boxes, and an Options Group Control. See the sample image given below.


The Combo Box Method

  1. Minimize Access and Maximize Excel.

  2. Enter a few Names of people, books, or anything else in Cells A9 to A17.

  3. Enter Value 2 in Cell C1 and minimize the Excel Application Window.

  4. Maximize MS-Access and open the Form in Design View.

  5. Disable the Control Wizards Button on the Toolbox. Select the Combo Box Tool and draw a Combo Box Control on the form in a way that it looks like a List Box. See the sample image given above.

  6. Display the Property Sheet and write the expression

    =DDE("Excel","Sheet1","R9C1:R17C1")

    In the Control Source Property of the Combo Box.

    You may give a Name to the Range: R9C1:R17C1 and use that Name in the expression, replacing the Range Address. To name the Excel Cell Range, highlight the Range, select Insert -> Name -> Define, and type the name, say List, in the Names in Workbook control. Replace the third Parameter R9C1:R17C1 with the Range Name List in the DDE Function.

  7. Open the Form in Normal View. The Names from the Excel Range will appear in the Combo Box.

Note: You cannot select any of these values and insert them into the Text Box portion of the Combo Box and use it in a data field.

The Option-Group Option

We will try one more example with the Options Group Control.

  1. Turn On the Control Wizard in the Toolbox. Select the Option Group Tool from the Toolbox and Draw an Option Group Control on the Form. Refer to the example given above.

  2. Type three Labels in the Wizard: Data View, Print Preview, and Print, or anything else you prefer, on the control, and click Finish.

  3. Click on the outer frame of the Options Group and display the Property Sheet (View -> Properties).

  4. Write the following expression in the Control Source Property:

=DDE("Excel","Sheet1","R1C3"

The selection of items on the Option Group will be based on the value given in Excel Cell C1. Now the value in Cell C1 is 2. The second item in the Options group will now show as selected. Change the Value in Cell C1 to 3 and refresh the Form as explained above, the option will change to 3.

Note: If the Excel Application is not active when you open the Form with the DDE() Function, then Access will show the following Error Message:

"You tried to open a form or report that includes a DDE or DDESend function in a calculated control that specifies an OLE server application."

"Do you want to start the application in Excel?"

If you respond with Yes, then the Excel Application will be started with Blank Sheets. You must open the Excel Workbook that provides information for the DDE() function manually, and display the values in the Access Form.

Next: Opening an Excel Database directly.

  1. Roundup Function of Excel in MS-Access
  2. Proper Function of Excel in Microsoft Access
  3. Appending Data from Excel to Access
  4. Writing Excel Data Directly into Access
  5. Printing MS-Access Report from Excel
  6. Copy-Paste Data From Excel to Access 2007
  7. Microsoft Excel Power in MS-Access
  8. Rounding Function MROUND of Excel
  9. MS-Access Live Data in Excel
  10. Access Live Data in Excel- 2
  11. Opening an Excel Database Directly
  12. Create an Excel Word File from Access
Powered by Blogger.