Quantcast
Channel: SQL Server Setup & Upgrade forum
Viewing all articles
Browse latest Browse all 7696

Application worked with XP, 32bit but not working with Windows 7, 64bit.

$
0
0

I have a VB application that I am trying to upgrade.  First I moved it to a new computer. The app worked on a XP, 32bit but when transferred to a Windows 7, 64 bit does not run when it is initially setting up communication to the data base.  

I use the sequence of SQLAllocEnv, SQLAllocConnect and then SQLConnect.   The first two steps seem to run fine without errors but when running SQLConnect, this error occurs:

[Microsoft][ODBC driver for Oracle][ORACLE]ORA-06413: Connection not open.

What am I missing or didn't I do?   Here is the code I used:

 Option Explicit
	 Private Declare Function SQLAllocEnv Lib "odbc32.dll" _
           (phenv As Long) As Integer
        Private Declare Function SQLAllocConnect Lib "odbc32.dll" _
           (ByVal henv As Long, phdbc As Long) As Integer
        Private Declare Function SQLConnect Lib "odbc32.dll" ( _
           ByVal hdbc As Long, ByVal szDSN As String, _
           ByVal cbDSN As Integer, ByVal szUID As String, _
           ByVal cbUID As Integer, ByVal szAuthStr As String, _
           ByVal cbAuthStr As Integer) As Integer
        Private Declare Function SQLFreeEnv Lib "odbc32.dll" _
           (ByVal henv As Long) As Integer
        Private Declare Function SQLFreeConnect Lib "odbc32.dll" _
           (ByVal hdbc As Long) As Integer
        Private Declare Function SQLError Lib "odbc32.dll" ( _
           ByVal henv As Long, ByVal hdbc As Long, ByVal hstmt As Long, _
           ByVal szSqlState As String, pfNativeError As Long, _
           ByVal szErrorMsg As String, ByVal cbErrorMsgMax As Integer, _
           pcbErrorMsg As Integer) As Integer
        Private Declare Function SQLDisconnect Lib "odbc32.dll" _
            (ByVal hdbc As Long) As Integer
'   ************************************************************************************
'   ************************************************************************************
'   THE FOLLOWING WAS ADDED TO PROVIDE CONNECTION POOLING.  MS CASE# SRZ060810001720
'   THIS IS FOUND @ www.support.microsoft.com/kb/237844/en-us
'   THIS SHOULD TURN ON CONNECTION POOLING, IT WILL ALLOW THE THE PC TO CONNECT
'   FASTER FOR SELL-OUTS BASED ON THE CONNECTION SHOULD ALREADY EXIST.
'
'   ************************************************************************************
        Const SQL_ATTR_CONNECTION_POOLING = 201
        Const SQL_CP_ONE_PER_DRIVER = 1
        Const SQL_IS_INTEGER = -6
        Const SQL_CP_OFF = 0
        Private Declare Function SQLSetEnvAttr Lib "odbc32.dll" ( _
                            ByVal EnvironmentHandle As Long, _
                            ByVal EnvAttribute As Long, _
                            ByVal ValuePtr As Long, _
                            ByVal StringLength As Long) As Integer
        Dim rc As Long
'   ****************************************************************
'   ORACLE SETUP VARIABLES
'   ****************************************************************
Public strOracleLocator$, strOracleProceedure$, strOracleServer$
Public strOracleSubinventory$, strOracleUserID$, strOracleUserPwd$
Public strOracleOrganizationCode As String
Public strOraclePart$, strPrevPartRan$
Public iOracleQty%, iOracleFileCount%
Public bOracleConnected As Boolean
Public bOracleSending As Boolean
Public bOracleEnabled As Boolean
Public bOracleLoggedON As Boolean
Public bOraclePartNumSame As Boolean
Public dOracleLoginQty As Double
Public bOracleConnectionPooling As Boolean
Public bLogONFailed As Boolean
Public bOracleSendManually As Boolean
Public dbOracleSendTime(2, 7) As Date
Public bOracleSendTimeEnable(2, 7) As Boolean
Public dtOracleTempTime(7) As Date
Public bOracleTempTime(7) As Boolean
Public bOracleSendByTime(3) As Boolean
Public bOracleSendByTimeOnce As Boolean
Public strOracleShapeColor As String
Public strOracleLabelText As String
Public bOracle(3) As Boolean
Public bSellAfter(1) As Boolean
Public bCoverONLY(1) As Boolean
Public bStoreOracleData As Boolean
'   ************************************************************************************
'   ************************************************************************************
Public bOracleSentDuringDownTime As Boolean
Public bOracleManualSend As Boolean
Public bOracleManualDidSend As Boolean
Public bOracleTransaction As Boolean
      Private Const SQL_SUCCESS As Long = 0
      Private Const SQL_SUCCESS_WITH_INFO As Long = 1
        Dim Cn As adodb.Connection
        Dim CPw1 As adodb.Command
        Dim CPw2 As adodb.Command
        Dim Rs As adodb.Recordset
        Dim Conn As String
        Dim QSQL As String
        Dim Oracle_Script As String
        Dim p_Organization As String
        Dim p_Item As String
        Dim p_Trx_Qty As Integer
        Dim p_Sub_Inventory As String
        Dim p_Locator As String
        Dim p_Organization_data As String
        Dim p_Item_data As String
        Dim p_Trx_Qty_data As Integer
        Dim p_Sub_Inventory_data As String
        Dim p_Locator_data As String
      Public Function IsValidODBCLogin(ByVal sDSN As String, _
         ByVal sUID As String, ByVal sPWD As String) As Boolean
      Dim henv As Long    'Environment Handle
'   ***********************************************************************
'   THIS IS A MICROSOFT DOWNLOAD TO VERIFY THE LOGIN ONTO A ODBC DATABASE
'   ***********************************************************************
      Dim hdbc As Long    'Connection Handle
      Dim iResult As Integer
        'Obtain Environment Handle
        iResult = SQLAllocEnv(henv)
        If iResult <> SQL_SUCCESS Then
          IsValidODBCLogin = False
          Exit Function
        End If
        'Obtain Connection Handle
        iResult = SQLAllocConnect(henv, hdbc)
        If iResult <> SQL_SUCCESS Then
          IsValidODBCLogin = False
          iResult = SQLFreeEnv(henv)
          Exit Function
        End If
        'Test Connect Parameters
        iResult = SQLConnect(hdbc, sDSN, Len(sDSN), sUID, Len(sUID), _
                  sPWD, Len(sPWD))
        If iResult <> SQL_SUCCESS Then
          If iResult = SQL_SUCCESS_WITH_INFO Then
            'The Connection has been successful, but SQLState Information
            'has been returned
            'Obtain all the SQLState Information
'            If frmOracle.Check1.Value Then ShowSQLErrorInfo hdbc, vbInformation
            IsValidODBCLogin = True
          Else
            'Obtain all the Error Information
'            If frmOracle.Check1.Value Then ShowSQLErrorInfo hdbc, vbExclamation
'   ***********************************************************************
'   THE FOLLOWING COMMAND HAS BEEN REM'D OUT TO PREVENT THE ERROR CODE FROM
'   POPPING UP ON THE SCREEN AND REQUIRING AN OPERATOR ACKNOWLEDGEMENT
'   ***********************************************************************
'            ShowSQLErrorInfo hdbc, vbExclamation
            IsValidODBCLogin = False
          End If
        Else
          IsValidODBCLogin = True
        End If
'   ***********************************************************************
'   THE FOLLOWING LINE WAS ADDED FROM A RECOMMENDATION FROM MICROSOFT
'   CASE # "SRZ060711002202" E-MAIL SUPPORT Ying Liu
'   FROM THE ORIGINAL DOWNLOAD FROM MICROSOFT'S KB, DID NOT HAVE THIS LINE
'   IN IT.  THIS ITEM IS DELCARED AT THE TOP OF THIS MODULE
'   ***********************************************************************
        iResult = SQLDisconnect(hdbc)
        'Free Connection Handle and Environment Handle
        iResult = SQLFreeConnect(hdbc)
        iResult = SQLFreeEnv(henv)
      End Function
      Public Sub ShowSQLErrorInfo(hdbc As Long, iMSGIcon As Integer)
'   ***********************************************************************
'   THIS IS A MICROSOFT DOWNLOAD TO VERIFY THE LOGIN ONTO A ODBC DATABASE
'   ***********************************************************************
      Dim iResult As Integer
      Dim hstmt As Long
      Dim sBuffer1 As String * 16, sBuffer2 As String * 255
      Dim lNative As Long, iOutlen As Integer
        sBuffer1 = String$(16, 0)
        sBuffer2 = String$(256, 0)
        Do 'Cycle though all the Errors
          iResult = SQLError(0, hdbc, hstmt, sBuffer1, lNative, sBuffer2, _
                    256, iOutlen)
          If iResult = SQL_SUCCESS Then
            If iOutlen = 0 Then
              MsgBox "Error -- No error information available", _
              iMSGIcon, "ODBC Logon"
            Else
              MsgBox Left$(sBuffer2, iOutlen), iMSGIcon, "ODBC Logon"
            End If
          End If
        Loop Until iResult <> SQL_SUCCESS
      End Sub


Viewing all articles
Browse latest Browse all 7696

Trending Articles