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 2.300 mal aufgerufen.
Anzeige
Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv (einschl. Beispielprojekt!) Ein absolutes Muss - Mehr als 650 MByte geballtes Wissen! - nahezu alle Tipps & Tricks und Workshops mit Beispielprojekten - Symbol-Galerie mit mehr als 3.200 Icons im modernen Look Weitere Infos - Online-Update-Funktion u.v.m. |
sevGraph (VB/VBA) ![]() Grafische Auswertungen Präsentieren Sie Ihre Daten mit wenig Aufwand in grafischer Form. sevGraph unterstützt hierbei Balken-, Linien- und Stapel-Diagramme (Stacked Bars), sowie 2D- und 3D-Tortendiagramme und arbeitet vollständig datenbankunabhängig! Buchempfehlung Tipp des Monats Dieter Otter Doppelte Werte bei Ausgabe eines Arrays unterdrücken Hier stellen wir 3 Möglichkeiten vor, wie man doppelte Werte bei der Ausgabe eines Arrays unterdrücken kann. Neu! sevISDN 1.0 ![]() Überwachung aller eingehender Anrufe! Die DLL erkennt alle über die CAPI-Schnittstelle eingehenden Anrufe und teilt Ihnen sogar mit, aus welchem Ortsbereich der Anruf stammt. Weitere Highlights: Online-Rufident, Erkennung der Anrufbehandlung u.v.m. |
||||||||||||||||
|
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. |
|||||||||||||||||


SQL-Serververbindung via DAO und DSN-Verbindung



