Improve company productivity with a Business Account.Sign Up

x
?
Solved

ADODB Connection to mdb on remote server

Posted on 2011-02-24
4
Medium Priority
?
1,019 Views
Last Modified: 2012-05-11
Experts,  I would like to enable a function in my Microsoft Access 2003 Database where records from the Local DB Table (PROBLEMLOG) are written to an Access mdb containing the exact same table on a remote http server.

The mdb is accessible at a URL similar to: http://www.myurl.com.au/mydblocation/mydbname.mdb

I'm new to ADODB connection strings and am having trouble working it out.  Please have a look at my code snippet at tell me what I am doing wrong.  

Thanks

Public Function uploadLog()
'Uploads the Problem to the Server based mdb

Dim cn As ADODB.Connection
Dim rsLog As DAO.Recordset
Dim rsWeb As ADODB.Recordset
Dim strSQL As String
Dim strCn As String
Dim myURL As String
Dim fld as field

'Get the local records to be send to the server DB
strSQL = "SELECT * FROM PROBLEMLOG WHERE SendToSupport=False"
Set rsLog = CurrentDb.OpenRecordset(strSQL, dbOpenDynaset)

If rsLog.RecordCount > 0 Then  
'There are some records to send
'Now Make connection to the server side Access 2003 mdb
'***** TROUBLE HERE!  *********    
    Set cn = New ADODB.Connection
    myURL = "//www.myurl.com.au/mydblocation/mydbname.mdb"
    strCn = "Provider=MS Remote; Remote Server=" & myURL _
    & "Remote Provider=Microsoft.Jet.OLEDB.4.0;"
    With cn
        .ConnectionString = strCn
        .CursorLocation = adUseServer
        .OPEN
    End With

'***** I THINK ITS OK FROM HERE ON? ********
'***** BUT CAN'T GET PAST THE CONNECTION BIT TO SEE *****

    'Open the Server Side Recordset for editing
    Set rsWeb = New ADODB.Recordset
    rsWeb.OPEN "SELECT * FROM PROBLEMLOG", cn
    
    'If connection made then continue to write
    rsLog.MoveFirst
    Do Until rsLog.EOF
        rsWeb.AddNew
        For Each fld In rsLog.Fields
            Debug.Print fld.NAME, rsLog(fld.NAME), fld.Type
            rsWeb(fld.NAME) = rsLog(fld.NAME)
        Next fld
        rsWeb.Update

'Edit the local record so that it it does get resend next time
        rsLog.Edit
        rsLog!SentToSupport = True
        rsLog.Update
'move onto the next record 
       rsLog.MoveNext
    Loop
End If
End Function

Open in new window

0
Comment
Question by:Carl Sudholz
  • 2
  • 2
4 Comments
 
LVL 20

Accepted Solution

by:
hes earned 750 total points
ID: 34969950
0
 
LVL 20

Expert Comment

by:hes
ID: 34969951
Sorry cap lock stuck
0
 

Author Closing Comment

by:Carl Sudholz
ID: 34975024
Provide the link to a solution that led me down the right track to solving the problem.

Thanks
0
 

Author Comment

by:Carl Sudholz
ID: 34975063
FYI,  Yep no good having an MDB on the server.  Solution was to:
1. set up a Database on mysql, with tables and user permissions
2. Install the MySQL connector driver (mysql-connector-odbc-5.1.8-win32.msi) from http://dev.mysql.com/downloads/connector/odbc/5.1.html
3. Set the connection string to:

Private Const conString As String = "Provider=MSDASQL;" & _
                                    "DRIVER={MySQL ODBC 5.1 Driver};" & _
                                    "SERVER=127.0.0.1;" & _
                                    "DATABASE=mydbname.mdb;" & _
                                    "UID=systemuser;" & _
                                    "PASSWORD=password1;" & _
                                    "OPTION=3"

From there the function works a treat pretty much as coded in the question.

Cheers
0

Featured Post

Get 10% Off Your First Squarespace Website

Ready to showcase your work, publish content or promote your business online? With Squarespace’s award-winning templates and 24/7 customer service, getting started is simple. Head to Squarespace.com and use offer code ‘EXPERTS’ to get 10% off your first purchase.

Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

Join & Write a Comment

I have had my own IT business for a very long time. I started mostly with hardware and after about a year started to notice a common theme. I had shelves with software boxes -- Peachtree, Quicken, Sage, Ouickbooks -- and yet most of my clients were…
When we develop an application in Ms Access 2016 we should also try to protect the queries, macros and table links. I know I may not have a permanent solution but for novice users, they will not manage to break your application. Below is the detail …
Do you want to know how to make a graph with Microsoft Access? First, create a query with the data for the chart. Then make a blank form and add a chart control. This video also shows how to change what data is displayed on the graph as well as form…
With just a little bit of  SQL and VBA, many doors open to cool things like synchronize a list box to display data relevant to other information on a form.  If you have never written code or looked at an SQL statement before, no problem! ...  give i…

608 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question