Der Zugriff auf den MS-SQL Server via ADO ist vielen bekannt. Wie sieht es aber aus, wenn man noch den DAO-Datenbankzugriff verwendet? In diesem Fall muss man beim Aufruf der "OpenDatabase"-Methode einen korrekten Connection-String mit Angabe eines DSN-Verbindungseintrags angeben: Dim sConn As String sConn = "ODBC;DSN=DSN_NAME;uid=sa;pwd=password" Set oDB = DBEngine.OpenDatabase("DSN_NAME", dbDriverNoPrompt, False, sConn) Für den Zugriff auf den MS-SQL Server via DAO muss also immer ein DSN-Verbindungseintrag im ODBC-Datenquellen-Manager existieren. Dieser kann natürlich manuell erstellt werden, was jedoch nicht immer dem Anwender zugemutet werden kann. Über die RegisterDatabase-Methode von DAO lässt sich der DSN-Verbindungseintrag auch bequem per Code erstellen. Existiert der Eintrag bereits, wird dieser mit den neuen Parameter aktualisiert, andernfalls wird der Eintrag neu erstellt. ' DSN-Verbindungseintrag erstellen/aktualisieren Public Function MakeDSNForSQLServer(ByVal sDSNName As String, _ ByVal sServer As String, _ ByVal sDatabase As String, _ ByVal sDescription As String) As Boolean On Error Resume Next Err.Clear DBEngine.RegisterDatabase sDSNName, "SQL Server", True, _ "Database=" & sDatabase & vbCr & _ "Description=" & sDescription & vbCr & _ "Server=" & sServer MakeDSNForSQLServer = (Err.Number = 0) On Error Goto 0 End Function Beispiel für den Aufruf: Dim sDSNName As String Dim sServer As String Dim sDatabase As String Dim sDescription As String Dim oDB As DAO.Database ' Name der DSN-Verbindung sDSNName = "TEST" ' SQL-Server sServer = Environ$("COMPUTERNAME") & "\SQL2000" ' Name der SQL-Datenbank sDatabase = "TESTDB" ' Beschreibung der DSN-Verbindung sDescription = "Testverbindung zum SQL-Server" ' DSN-Verbindungseintrag erstellen/aktualisieren If MakeDSNForSQLServer(sDSNName, sServer, sDatabase, sDescription) Then ' Verbindung über DSN-Eintrag herstellen Dim sConn As String sConn = "ODBC;DSN=" & sDSNName & ";uid=sa;pwd=Password" Set oDB = DBEngine.OpenDatabase(sDSNName, dbDriverNoPrompt, False, sConn) ... Else MsgBox "Fehler beim Einrichten/Aktualisieren der DSN-Verbindung" & vbCrLf & _ CStr(Err.Number) & " " & Err.Description, vbExclamation + vbOKOnly End If Dieser Tipp wurde bereits 25.854 mal aufgerufen. Voriger Tipp | Zufälliger Tipp | Nächster Tipp
Anzeige
Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv Vol.6 (einschl. Beispielprojekt!) Ein absolutes Muss - Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! - nahezu alle Tipps & Tricks und Workshops mit Beispielprojekten - Symbol-Galerie mit mehr als 3.200 Icons im modernen Look Weitere Infos - 4 Entwickler-Vollversionen (u.a. sevFTP für .NET), Online-Update-Funktion u.v.m. |
TOP! Unser Nr. 1 Neu! sevDataGrid 3.0 Mehrspaltige Listen, mit oder ohne DB-Anbindung. Autom. Sortierung, Editieren von Spalteninhalten oder das interaktive Hinzufügen von Datenzeilen sind ebenso möglich wie das Erstellen eines Web-Reports. Tipp des Monats März 2024 Dieter Otter UTF-8 Konvertierung von Dateien und Strings VB6 selbst verfügt über keine Funktionen zur UTF-8 Konvertierung von Daten. Mit Hilfe des ADODB.Stream-Objekts lassen sich diese fehlenden Funktionen aber schnell nachrüsten. TOP Entwickler-Paket TOP-Preis!! Mit der Developer CD erhalten Sie insgesamt 24 Entwickler- komponenten und Windows-DLLs. Die Einzelkomponenten haben einen Gesamtwert von 1605.50 EUR... |
||||||||||||||||
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein. |