CSV Connector for MS Access
CSV Connector can be used to extract and output CSV data from Web URL/REST API web service calls (Web URL) or direct CSV String (variables or DB columns) or local CSV files data.
In this article you will learn how to quickly and efficiently integrate CSV data in MS Access without coding. We will use high-performance CSV Connector to easily connect to CSV and then access the data inside MS Access.
Let's follow the steps below to see how we can accomplish that!
CSV Connector for MS Access is based on ZappySys CSV Driver which is part of ODBC PowerPack. It is a collection of high-performance ODBC drivers that enable you to integrate data in SQL Server, SSIS, a programming language, or any other ODBC-compatible application. ODBC PowerPack supports various file formats, sources and destinations, including REST/SOAP API, SFTP/FTP, storage services, and plain files, to mention a few.
Create ODBC Data Source (DSN) based on ZappySys CSV Driver
Step-by-step instructions
To get data from CSV using MS Access we first need to create a DSN (Data Source) which will access data from CSV. We will later be able to read data using MS Access. Perform these steps:
- 
	    Download and install ODBC PowerPack. 
- 
	Open ODBC Data Sources (x64):   
- 
	Create a User data source (User DSN) based on ZappySys CSV Driver ZappySys CSV Driver  - 
	                Create and use User DSN 
	                if the client application is run under a User Account.
                    This is an ideal option in design-time , when developing a solution, e.g. in Visual Studio 2019. Use it for both type of applications - 64-bit and 32-bit.
- 
	                Create and use System DSN 
	                if the client application is launched under a System Account, e.g. as a Windows Service.
                    Usually, this is an ideal option to use in a production environment . Use ODBC Data Source Administrator (32-bit), instead of 64-bit version, if Windows Service is a 32-bit application.
 
- 
	                Create and use User DSN 
	                if the client application is run under a User Account.
                    This is an ideal option 
- 
    Select Url or File. 
 Read CSV API in MS Access- 
                Paste the following Url. In this example, We are using Zip format CSV File URL, but you need to refer your CSV File/URL. https://zappysys.com/downloads/files/test/cust-1.csv.zipClick on Test Connection button to view whether the Test Connection is SUCCESSFUL or Not.  
 Read CSV File in MS Access- 
                You can use pass single file or multiple file path using wildcard pattern in path and you can use select single file by clicking [...] path button or multiple file using wildcard pattern in path. 
 Note: If you want to operation with multiple files then use wild card pattern as below (when you use wild card pattern in source path then system will treat target path as folder regardless you end with slash) C:\SSIS\Test\reponse.csv (will read only single reponse.csv file) C:\SSIS\Test\j*.csv (all files starting with file name j) C:\SSIS\Test\*.csv (all files with .csv Extension and located under folder subfolder) Click on Test Connection button to view whether the Test Connection is SUCCESSFUL or Not.  
 
- 
                
- 
    Once you configured a data source, you can preview data. Hit Preview tab, and use similar settings to preview data: 
   
- 
    Click OK to finish creating the data source 
- 
    That's it; we are done. In a few clicks we configured the read the CSV data using ZappySys CSV Connector. 
Read data in Microsoft Access from the ODBC data source
- 
    First of all, open MS Access and create a new MS Access database. 
- 
    In the next step, start loading ODBC data source we created:   
- 
    Then click next until data source selection window appears. Select the data source we created in one of the previous steps and hit OK: CsvDSN  
- 
    Continue with tables and views selection. You can extract multiple tables or views: 
   
- 
    Finally, wait while data is being loaded and once done you should see a similar view:   
Using Linked Table for Live Data (Slow)
Linked tables in Microsoft Access are crucial for online databases because they enable real-time access to centralized data, support scalability, facilitate collaboration, enhance data security, ease maintenance tasks, and allow integration with external systems. They provide a flexible and efficient way to work with data stored in online databases, promoting cross-platform compatibility and reducing the need for data duplication.
- 
            Real-Time Data Access:
 Access can interact directly with live data in online databases, ensuring that users always work with the most up-to-date information.
- 
            Centralized Data Management:
 Online databases serve as a centralized repository, enabling efficient management of data from various locations.
- 
            Ease of Maintenance:
 Updates or modifications to the online database structure are automatically reflected in Access, streamlining maintenance tasks.
- 
            Adaptability to Changing Requirements:
 Linked tables provide flexibility, allowing easy adaptation to changing data storage needs or migration to different online database systems.
Let's create the linked table.
- 
            Launch Microsoft Access and open the database where you want to create the linked table. 
- 
            Go to the "External Data" tab on the Ribbon. >> "New Data Source" >> "From Other Sources" >> "ODBC Database"   
- 
            Select the option "Link to Data Source by creating a linked table:   
- 
            Continue by clicking 'Next' until the Data Source Selection window appears. Navigate to the Machine Data Source tab and select the desired data source established in one of the earlier steps. Click 'OK' to confirm your selection. CsvDSN  
- 
            Proceed to the selection of Tables and Views. You have the option to extract multiple tables or views: 
   
- 
            When prompted to select Unique Key column DO NOT select any column(s) and just click OK:   
- 
            Finally, Simply double-click the newly created Linked Table to load the data:   
Guide to Effectively Addressing Known Issues
Discover effective strategies to address known issues efficiently in this guide. Get solutions and practical tips to streamline troubleshooting and enhance system performance, ensuring a smoother user experience.
Fewer Rows Imported
The reason for this is that MS Access has a default query timeout of 60 seconds, which means it stops fetching data if the query takes longer than that. As a result, only a limited number of rows are fetched within this time frame.
    To address this, we can adjust the Query Timeout by following the steps below.
    
     
The path may vary depending on the MS Access bitness, such as 32-bit versus 64-bit.
\HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Jet\4.0\Engines\ODBC
\HKEY_LOCAL_MACHINE\SOFTWARE\WOW6432Node\Microsoft\Jet\4.0\Engines\ODBC
\HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Office\ClickToRun\REGISTRY\MACHINE\Software\Microsoft\Office\16.0\Access Connectivity Engine\Engines\ODBC
We can identify this issue by examining the Fiddler Log, as MS Access doesn't display any error regarding partial import, which is quite unusual
    Please refer to this link : How to use Fiddler to analyze HTTP web requests
    
     
#Deleted word appears for column value in MS Access for Linked Table mode
If you used Linked Table mode to get external data and it shows #deleted word rather than actual value for column after you open then most likely its following issue.
    Make sure to re-create Linked Table and DO NOT select any key column when prompted (Just click OK)
     
    
    How to Fix
    
     
Table Selection UI Opening Delays
The Table selection UI takes a significant amount of time to open after clicking the 'New Data Source' -> 'Other Data Sources' -> 'ODBC'
    The reason for this issue is that MS Access sends a dummy query, leading to several unnecessary pagination cycles before an error is thrown. To mitigate this, we can prevent wasted cycles by configuring the 'Throw error if no match' setting on the Filter Options Tab.
    
     
Enhancing Performance through Metadata Addition (Reduces Query Time)
    We can optimize query performance by creating Virtual Tables (i.e. views with custom SQL) on Datasource and incorporating META=static columns. Learn how to capture static metadata in this guide.
    
        Performance Options - Generate Metadata Manually
    
    Execute the query initially, save the metadata by selecting 'Save to Meta' (choose Compact Format), and then click 'Save to Clipboard.' Utilize the resulting list by pasting it into the META attribute as follows: 'META=paste here.'
    
     
SELECT * FROM products
    WITH(
        META='id:String(20); title:String(100);  description:String(500);'
    )
Optimize Workflow with Automated Import
Employ Automated Import when Linked Tables are not feasible, and we need to depend on Imported Tables with static data.
While using Linked Tables sometime it encounter errors, and we are left with no alternative but to utilize Imported Tables, Automatic Refresh becomes crucial in such scenarios.
Here's a guide on automating refreshes. We can set up automatic refresh on different events, such as when the database opens, a form is opened, or a button is clicked.
To initiate the import process, follow these steps:
- Perform the data import using the standard manual steps.
- In the final step, we'll encounter a checkbox labeled 'Save Import Steps.' Ensure to check this option.
- After saving the steps, we can locate their name in the Save Imports UI. Identify the name associated with the saved steps.
- "Now, we can execute the code as shown below:"
Private Sub cmdYes_Click()
    Label0.Visible = True
    DoCmd.RunSavedImportExport "Import-DATA.products"
    Label0.Visible = False
End Sub
    
Configuring pagination in the CSV Driver
ZappySys CSV Driver equips users with powerful tools for seamless data extraction and management from REST APIs, leveraging advanced pagination methods for enhanced efficiency. These options are designed to handle various types of pagination structures commonly used in APIs. Below are the detailed descriptions of these options:
- Page-based Pagination: This method works by retrieving data in fixed-size pages from the Rest API. It allows you to specify the page size and navigate through the results by requesting different page numbers, ensuring that you can access all the data in a structured manner. 
- Offset-based Pagination: With this approach, you can extract data by specifying the starting point or offset from which to begin retrieving data. It allows you to define the number of records to skip and fetch subsequent data accordingly, providing precise control over the data extraction process. 
- Cursor-based Pagination: This technique involves using a cursor or a marker that points to a specific position in the dataset. It enables you to retrieve data starting from the position indicated by the cursor and proceed to subsequent segments, ensuring that you capture all the relevant information without missing any records. 
- Token-based Pagination: In this method, a token serves as a unique identifier for a specific data segment. It allows you to access the next set of data by using the token provided in the response from the previous request. This ensures that you can systematically retrieve all the data segments without duplication or omission. 
Utilizing these comprehensive pagination features in the ZappySys CSV Driver facilitates efficient data management and extraction from REST APIs, optimizing the integration and analysis of extensive datasets.
For more detailed steps, please refer to this link: How to do REST API Pagination in SSIS / ODBC Drivers
Authentication
ZappySys offers various authentication methods to securely access data from various sources. These authentication methods include OAuth, Basic Authentication, Token-based Authentication, and more, allowing users to connect to a wide range of data sources securely.
ZappySys Authentication is a robust system that facilitates secure access to data from a diverse range of sources. It includes a variety of authentication methods tailored to meet the specific requirements of different data platforms and services. These authentication methods may involve:
- OAuth: ZappySys supports OAuth for authentication, which allows users to grant limited access to their data without revealing their credentials. It's commonly used for applications that require access to user account information. 
- Basic Authentication: This method involves sending a username and password with every request. ZappySys allows users to securely access data using this traditional authentication approach. 
- Token-based Authentication: ZappySys enables users to utilize tokens for authentication. This method involves exchanging a unique token with each request to authenticate the user's identity without revealing sensitive information. 
By implementing these authentication methods, ZappySys ensures the secure and reliable retrieval of data from various sources, providing users with the necessary tools to access and integrate data securely and efficiently. For more comprehensive details on the authentication process, please refer to the official ZappySys documentation or reach out to their support team for further assistance.
For more details, please refer to this link: ZappySys Connections
Conclusion
In this article we showed you how to connect to CSV in MS Access and integrate data without any coding, saving you time and effort.
We encourage you to download CSV Connector for MS Access and see how easy it is to use it for yourself or your team.
If you have any questions, feel free to contact ZappySys support team. You can also open a live chat immediately by clicking on the chat icon below.
Download CSV Connector for MS Access Documentation
 
                     
         
                 
             
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                 
		             
		             
		             
		             
		             
		             
		             
		             
		             
		             
		             
		             
		             
		             
		             
		             
		            