DOCUMENT:Q247440  13-MAY-2002  [winnt]
TITLE   :HOWTO: Rename Jet 3.51 ODBC Drivers in Windows 2000
PRODUCT :Microsoft Windows NT
PROD/VER::2000
OPER/SYS:
KEYWORDS:kbDatabase kbDBase kbDriver kbJET kbOSWin2000 kbODBC kbVBp kbvfp kbXBase kbGrpDSVBDB kb

======================================================================

-------------------------------------------------------------------------------
The information in this article applies to:

 - Microsoft Windows 2000 Advanced Server 
 - Microsoft Windows 2000 Server 
 - Microsoft Windows 2000 Professional 
-------------------------------------------------------------------------------

IN THIS TASK
------------

 - SUMMARY

    - Setting Up the Jet 3.5 ODBC Drivers

 - Copying the Files
 - Making System Links
 - Creating the Registry File
 - Merging the Registry File
 - Using the Drivers

 - REFERENCES

SUMMARY
=======

Microsoft Windows 2000 comes with MDAC 2.5 preinstalled. The ODBC driver for
Microsoft Access 2000 in MDAC 2.5 provides additional functionality over the
3.51 versions of the driver, but some previous functionality was removed.
Existing applications that use the ODBC driver for Microsoft Access
automatically use the new drivers. Applications can fail if they require
functionality that the new ODBC drivers do not provide.

This article provides a method to install the Jet 3.51 ODBC drivers on your
Microsoft Windows 2000 computer. After the Jet 3.51 driver is installed, it must
be renamed which in turn enables Jet 3.51 and 4.0 to simultaneously exist on a
Windows 2000 computer. After completing this installation, applications may have
access to both Jet 3.51 and 4.0 drivers. Microsoft provides programming examples
for illustration only, without warranty either expressed or implied, including,
but not limited to, the implied warranties of merchantability and/or fitness for
a particular purpose. This article assumes that you are familiar with the
programming language being demonstrated and the tools used to create and debug
procedures. Microsoft support professionals can help explain the functionality
of a particular procedure, but they will not modify these examples to provide
added functionality or construct procedures to meet your specific needs. If you
have limited programming experience, you may want to contact a Microsoft
Certified Partner or the Microsoft fee-based consulting line at (800) 936-5200.
For more information about Microsoft Certified Partners, please visit the
following Microsoft Web site:

   http://www.microsoft.com/partner/referral/

For more information about the support options that are available and about how
to contact Microsoft, visit the following Microsoft Web site:

   http://support.microsoft.com/default.aspx?scid=fh;EN-US;CNTACTMS

Upgrading your Microsoft Access ODBC driver from version 3.5 to version 4.0
provides your applications a number of benefits, including the ability to read
and write Jet 4.0 format MDB files. However, if your application uses the IISAM
drivers, some functionality is lost, which could result in your application not
working.

The lost functionality includes dropping the FoxPro IISAM and making the dBase
and Paradox IISAM drivers give read-only access to your files.

For new application development, there are several possible workarounds:

 - Use the FoxPro ODBC driver. It provides more functionality than the IISAM
   driver, although you cannot use the Seek method.

 - The dBase and Paradox IISAMs do enable updating files if the Borland Database
   Engine (BDE) is installed. However, this must be licensed from Inprise.

 - Use the steps outlined in this article to install the Jet 3.51 ODBC and Jet 4
   ODBC drivers simultaneously on your Microsoft Windows 2000 computer.

   NOTE: This last alternative only works if using Windows 2000 and does not work
   if using Windows NT 4.0 or Windows 95 or 98.


Setting Up the Jet 3.5 ODBC Drivers
-----------------------------------

The steps described below enable your ODBC applications that use Jet 3.5 and Jet
4.0 to co-exist and run simultaneously on a Windows 2000 computer. It is assumed
that Jet 3.5 and Jet 4.0 are both installed on the computer and the ODBC driver
is currently version 4.0.

If you need to get Jet 3.5 on the computer, you can install any DAO 3.5
application that uses the appropriate IISAM drivers, or you can copy and
register the files outlined in the following Knowledge Base articles:

   Q240377 HOWTO: Insuring Jet 3.5 Is Installed Correctly

Applications that use the Jet 3.5 ODBC drivers have to use a different DSN or
connect string than ones that use the default Microsoft Access (Jet 4.0) ODBC
driver.

The ODBC drivers on your system are defined by Registry keys under:

   HKEY_LOCAL_MACHINE\SOFTWARE\ODBC

This article provides the following:

 - A list of files to copy to your Windows 2000 computers.

 - A program to build some links to enable the ODBC drivers to function
   correctly outside the system and application directories.

 - A file to register them with a new driver name. In this case, the driver
   names have the words "Jet 351" inserted into them.

Copying the Files
-----------------

1. Locate the following files on your Visual Basic 5.0 or Visual Basic 6.0
   (pre-SP3) CD. They are in the folder \OS\System on CD 1 of the Visual Studio
   98 CDs. For example:

   ODBCJT32.DLL
   ODBCJI32.DLL
   ODBCTL32.DLL
   ODDBSE32.DLL
   ODEXL32.DLL
   ODFOX32.DLL
   ODPDX32.DLL
   ODTEXT32.DLL

2. Copy the files to a directory, such as C:\JET351ODBC, on your Windows 2000
   computer. The directory must be on the same drive as your Windows 2000
   installation. If it is on a different drive, the system links do not build
   correctly in the next step.

Making System Links
-------------------

The ODBC driver looks in the directory where it is located for certain system
files. However, you cannot just copy these files into the directory if it is
different than the application directory because the files might conflict with
ones of the same name that are loaded by the host application.

Windows 2000 introduces the concept of Hard Links, which enable you to create a
file in the application directory that points to a file in another directory.
This is different than the .lnk files used to redirect applications. The hard
link ensures that only one copy of the DLL is loaded into the process space.

The following Visual Basic code demonstrates how to create the links required by
the ODBC driver:

1. In Visual Basic, create a new Standard EXE. Form1 is created by default.

2. On the Project menu, select Add Module, then add a code module. Module1 is
   created by default.

3. From the Project menu, select Project1 Properties. From the Startup Object
   drop-down list, select Sub Main. Click OK.

4. Paste the following code into the General Declarations section of Module1:

   Option Explicit

   Private Declare Function CreateHardLink Lib "KERNEL32" Alias "CreateHardLinkA" _
          (ByVal LinkPath As String, _
           ByVal FilePath As String, _
           ByVal Security As Long) As Long

   Private Const SysDir As String = "c:\winnt\system32\"
   Private Const ODBCDir As String = "c:\jet351odbc\"

   Sub Main()
     CreateLink "OLE32.DLL"
     CreateLink "MSJTER35.DLL"
     CreateLink "VBAJET32.DLL"
     CreateLink "EXPSRV.DLL"
   End Sub

   Private Sub CreateLink(FileName As String)
   Dim Result As Long
     Result = CreateHardLink(ODBCDir & FileName, SysDir & FileName, 0)
     If Result = 0 Then
       Debug.Print "Create Hard link failed on file " & FileName & " with error " & Err.LastDllError
     End If
   End Sub

5. If necessary, change the directory names and drive letters to match your
   particular computer.

6. Run the Visual Basic project. You only need to run this code one time to
   permanently create the links.

Creating the Registry File
--------------------------

The following steps enter the Jet ODBC 3.51 file locations into the Windows
Registry:

1. Use the Windows Notepad applet to create a new Text document.

2. Copy the following entries and paste them into the new Text document:

Windows Registry Editor Version 5.00

[HKEY_LOCAL_MACHINE\SOFTWARE\ODBC\ODBCINST.INI]

[HKEY_LOCAL_MACHINE\SOFTWARE\ODBC\ODBCINST.INI\Microsoft Jet 351 Access Driver (*.mdb)]
"UsageCount"=dword:0000000c
"Driver"="C:\\Jet351ODBC\\odbcjt32.dll"
"Setup"="C:\\Jet351ODBC\\odbcjt32.dll"
"APILevel"="1"
"ConnectFunctions"="YYN"
"DriverODBCVer"="02.50"
"FileUsage"="2"
"FileExtns"="*.mdb"
"SQLLevel"="0"
"s"="YYN"
"CPTimeout"="60"

[HKEY_LOCAL_MACHINE\SOFTWARE\ODBC\ODBCINST.INI\Microsoft Jet 351 dBase Driver (*.dbf)]
"UsageCount"=dword:0000000b
"Driver"="C:\\Jet351ODBC\\odbcjt32.dll"
"Setup"="C:\\Jet351ODBC\\oddbse32.dll"
"APILevel"="1"
"ConnectFunctions"="YYN"
"DriverODBCVer"="02.50"
"FileUsage"="1"
"FileExtns"="*.dbf,*.ndx,*.mdx"
"SQLLevel"="0"
"CPTimeout"="<not pooled>"

[HKEY_LOCAL_MACHINE\SOFTWARE\ODBC\ODBCINST.INI\Microsoft Jet 351 Excel Driver (*.xls)]
"UsageCount"=dword:00000009
"Driver"="C:\\Jet351ODBC\\odbcjt32.dll"
"Setup"="C:\\Jet351ODBC\\odexl32.dll"
"APILevel"="1"
"ConnectFunctions"="YYN"
"DriverODBCVer"="02.50"
"FileUsage"="1"
"FileExtns"="*.xls"
"SQLLevel"="0"
"CPTimeout"="<not pooled>"

[HKEY_LOCAL_MACHINE\SOFTWARE\ODBC\ODBCINST.INI\Microsoft Jet 351 FoxPro Driver (*.dbf)]
"UsageCount"=dword:00000008
"Driver"="C:\\Jet351ODBC\\odbcjt32.dll"
"Setup"="C:\\Jet351ODBC\\odfox32.dll"
"APILevel"="1"
"ConnectFunctions"="YYN"
"DriverODBCVer"="02.50"
"FileUsage"="1"
"FileExtns"="*.dbf,*.cdx,*.idx,*.ftp"
"SQLLevel"="0"
"CPTimeout"="<not pooled>"

[HKEY_LOCAL_MACHINE\SOFTWARE\ODBC\ODBCINST.INI\Microsoft Jet 351 Paradox Driver (*.db )]
"UsageCount"=dword:00000009
"Driver"="C:\\Jet351ODBC\\odbcjt32.dll"
"Setup"="C:\\Jet351ODBC\\odpdx32.dll"
"APILevel"="1"
"ConnectFunctions"="YYN"
"DriverODBCVer"="02.50"
"FileUsage"="1"
"FileExtns"="*.db"
"SQLLevel"="0"
"CPTimeout"="<not pooled>"

[HKEY_LOCAL_MACHINE\SOFTWARE\ODBC\ODBCINST.INI\Microsoft Jet 351 Text Driver (*.txt; *.csv)]
"UsageCount"=dword:0000000a
"Driver"="C:\\Jet351ODBC\\odbcjt32.dll"
"Setup"="C:\\Jet351ODBC\\odtext32.dll"
"APILevel"="1"
"ConnectFunctions"="YYN"
"DriverODBCVer"="02.50"
"FileUsage"="1"
"FileExtns"="*.,*.asc,*.csv,*.tab,*.txt,*.csv"
"SQLLevel"="0"
"CPTimeout"="<not pooled>"

[HKEY_LOCAL_MACHINE\SOFTWARE\ODBC\ODBCINST.INI\ODBC Drivers]
"Microsoft Jet 351 Access Driver (*.mdb)"="Installed"
"Microsoft Jet 351 dBase Driver (*.dbf)"="Installed"
"Microsoft Jet 351 Excel Driver (*.xls)"="Installed"
"Microsoft Jet 351 FoxPro Driver (*.dbf)"="Installed"
"Microsoft Jet 351 Text Driver (*.txt; *.csv)"="Installed"
"Microsoft Jet 351 Paradox Driver (*.db )"="Installed"

3. If necessary, change the directory names and drive letters to match the ones
   on your system.

4. Save to a file with a .reg extension, such as Jet351ODBC.reg.

Merging the Registry File
-------------------------

There are several ways to merge the newly created REG file into the Windows NT
Registry:

 - Double-click on the file.

 - Alternate-click on the file and choose Merge.

 - Use the Windows REGEDIT program.

Note that you only need to merge the REG file once to permanently enter the
information into the Registry.
To merge the file using the Windows REGEDIT program:

1. On the Windows 2000 Start menu, choose Run.

2. In the Open: text box, type:

"C:\WinNT\RegEdit.exe" (without the quotation marks)

3. On the Registry menu, choose Import Registry File. Browse to the newly
   created .reg file, select it, then click Open. A message box appears that
   displays the .reg file information that was entered into the registry.

Using the Drivers
-----------------

Once you have created the hard links and entered the information into the
registry, you can use the ODBC Driver Manager to create DSNs with the renamed
driver. You can also use DSN-less connections in your application by referencing
the renamed driver. The driver names are:

   Microsoft Jet 351 Access Driver (*.mdb)
   Microsoft Jet 351 dBase Driver (*.dbf)
   Microsoft Jet 351 Excel Driver (*.xls)
   Microsoft Jet 351 FoxPro Driver (*.dbf)
   Microsoft Jet 351 Text Driver (*.txt; *.csv)
   Microsoft Jet 351 Paradox Driver (*.db )

You can compile the application and use it on any other Windows 2000 computer
that has the necessary links and registry information. If you are going to
redistribute the application to a Windows 2000 computer that has not had the
changes made, you have to create a patch program to perform the three steps
described above, including detecting the drive and directory that the operating
system is installed on and dynamically using this data to point to the correct
directories.

REFERENCES
==========

Starting with Microsoft Data Access Components (MDAC) version 2.6, MDAC no longer
contains the following Jet components:

 - Microsoft Jet
 - Microsoft Jet OLE DB Provider
 - ODBC Desktop Database Drivers

For additional information, click the article number below to view the article in
the Microsoft Knowledge Base:

   Q239114 ACC2000: Updated Version of Microsoft Jet 4.0 Available in Download
   Center

The "MDAC 2.5 Stack and Windows File Protection" white paper contains a full list
of the components that are shipped with MDAC 2.5, along with a discussion of
Windows File Protection. Refer to this white paper for more information about
the Jet dynamic-link libraries (DLLs) that are included in MDAC 2.5, which are
no longer a part of MDAC 2.6.

For more information about MDAC 2.5 and Windows File Protection, see the
following Microsoft Web site:

   http://www.microsoft.com/data/mdacwfp.htm

Microsoft Developer Network topic: CreateHardLink

Additional query words: Installable ISAM

======================================================================
Keywords          : kbDatabase kbDBase kbDriver kbJET kbOSWin2000 kbODBC kbVBp kbvfp kbXBase kbGrpDSVBDB kbGrpDSMDAC kbDSupport kbMDAC250 kbMDACNoSweep kbAudITPro kbHOWTOmaster 
Technology        : kbwin2000AdvServ kbwin2000AdvServSearch kbwin2000Serv kbwin2000ServSearch kbwin2000Search kbwin2000ProSearch kbwin2000Pro kbWinAdvServSearch
Version           : :2000
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 2002.