Mysql
 sql >> Datenbank >  >> RDS >> Mysql

DSN-lose Verbindung zum MySQL-Server in ms-access merkt sich Benutzernamen und Passwort nicht

Ich habe mit Hilfe dieses Microsoft-Artikels eine Antwort gefunden . Anstatt die RefreshLink-Methode zu verwenden, löschen Sie den Link und erstellen Sie ihn mit der dbAttachedODBC-Option neu:

Public Sub relink_mysql_tables(mysql_connection As String)

Dim db As Database
Dim tblDef As TableDef
Dim sLocalTableName As String
Dim sRemoteTableName As String    

' new collection '
Dim newTableDefs As New Collection

' current database '
Set db = CurrentDb()

' create new table defs '
For Each tblDef In db.TableDefs
    If (tblDef.Attributes And TableDefAttributeEnum.dbAttachedODBC) Then
        sLocalTableName = tblDef.Name
        sRemoteTableName = tblDef.SourceTableName

        ' create new linked table def '
        Set tblDef = db.CreateTableDef(sLocalTableName, dbAttachSavePWD, sRemoteTableName, mysql_connection)
        newTableDefs.Add tblDef         

    End If
Next

' delete old table defs '
For Each tblDef In newTableDefs
    db.TableDefs.Delete tblDef.Name
Next

' add new table defs to current database '
For Each tblDef In newTableDefs
    db.TableDefs.Append tblDef
Next

Die Verbindungszeichenfolge ist dieselbe wie zuvor, jedoch mit dem Präfix "ODBC;":

ODBC;DRIVER={MySQL ODBC 5.1 Driver};Server=myserver;Database=mydatabase;Uid=myusername;Pwd=mypassword;Option=3