DOCUMENT:Q281755 13-JUN-2001 [vbwin] TITLE :HOWTO: Connect to FileMaker Pro from Visual Basic with ODBC PRODUCT :Microsoft Visual Basic for Windows PROD/VER::6.0 OPER/SYS: KEYWORDS:kbDatabase kbMDAC kbGrpDSVBDB kbDSupport ====================================================================== ------------------------------------------------------------------------------- The information in this article applies to: - Microsoft Visual Basic Professional Edition for Windows, version 6.0 - Microsoft Visual Basic Enterprise Edition for Windows, version 6.0 ------------------------------------------------------------------------------- SUMMARY ======= FileMaker Pro version 5.0 now supports Open Database Connectivity (ODBC). This article describes one method that you can use to connect to a FileMaker Pro 5.0 database from Visual Basic with ODBC. MORE INFORMATION ================ An ODBC driver shipped with FileMaker Pro beginning with version 5.0. In prior versions, it was necessary to use drivers from third-party resources to have ODBC connectivity to this data source. Unlike most other ODBC data sources, in order to use ODBC to connect to FileMaker Pro, you must have the FileMaker Pro software installed on your computer. It is also necessary to leave the FileMaker Pro software running with the database open while you try to connect. Steps to Connect ---------------- 1. Open FileMaker Pro version 5.0. 2. Open the Sample02.FP5 sample database. If you use the trial version of FileMaker Pro, this file is located in C:\Program Files\FileMaker\FileMaker Pro 5 Trial\Tutorial\Sample Files\Sample02.fp5. 3. On the File menu, select Sharing from FileMaker Pro, and then check Local Data Access Companion in the dialog box that appears. 4. Close this dialog box, but do not close FileMaker Pro or the database. 5. Create a Data Source Name (DSN) called FMTest with the FileMaker Pro ODBC Driver. 6. Open a new Standard EXE project in Visual Basic. 7. Set the following references in the Project References dialog box: Microsoft Active X Data Objects 2.X 8. Copy the following code into the Form1 code window: Private Sub Form_Load() Dim cn As ADODB.Connection Dim rs As ADODB.Recordset Dim counter As Integer Set cn = New ADODB.Connection Set rs = New ADODB.Recordset cn.Open "Provider=MSDASQL.1;Data Source=FMTest;database=Sample02.fp5" cn.CursorLocation = adUseClient rs.Open "Select * from Sample02.fp5", cn For counter = 0 To rs.Fields.Count - 1 Debug.Print rs.Fields(counter).Name Next counter Do While Not rs.EOF Debug.Print rs.Fields(0).Value rs.MoveNext Loop End Sub 9. Press the F5 key to run the code. 10. Check the Immediate window to confirm that the field names and the value of the first field are returned. Additional query words: ====================================================================== Keywords : kbDatabase kbMDAC kbGrpDSVBDB kbDSupport Technology : kbVBSearch kbAudDeveloper kbZNotKeyword6 kbZNotKeyword2 kbVB600Search kbVBA600 kbVB600 Version : :6.0 Issue type : kbhowto ============================================================================= THE INFORMATION PROVIDED IN THE MICROSOFT KNOWLEDGE BASE IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND. MICROSOFT DISCLAIMS ALL WARRANTIES, EITHER EXPRESS OR IMPLIED, INCLUDING THE WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL MICROSOFT CORPORATION OR ITS SUPPLIERS BE LIABLE FOR ANY DAMAGES WHATSOEVER INCLUDING DIRECT, INDIRECT, INCIDENTAL, CONSEQUENTIAL, LOSS OF BUSINESS PROFITS OR SPECIAL DAMAGES, EVEN IF MICROSOFT CORPORATION OR ITS SUPPLIERS HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. SOME STATES DO NOT ALLOW THE EXCLUSION OR LIMITATION OF LIABILITY FOR CONSEQUENTIAL OR INCIDENTAL DAMAGES SO THE FOREGOING LIMITATION MAY NOT APPLY. Copyright Microsoft Corporation 2001.