Wer mit MS SQL-Servern arbeitet, kennt die Möglichkeit über den Query Analyzer sein SQL Statement zu überprüfen, bevor es ausgeführt wird. Es wäre doch eine feine Sache, wenn wir diese Funktionalität dem Anwender in unserem Programm auch zur Verfügung stellen könnten. Doch wie macht der Query Analyzer das, und wie kann man es in VB umsetzen? Eigentlich ganz einfach. Wir versetzen den SQL-Server in den "NOEXEC" Modus. Damit wird kein SQL Statement ausgeführt, jedoch wird die Syntax überprüft. Fügen Sie den nachfolgenden Code in ein Modul ein: ' SQL-Syntax-Check Public Function SQLCheck(ActiveConn As ADODB.Connection, _ ByVal sSQL As String) As Boolean Dim oCmd As New ADODB.Command Dim oRSCmd As ADODB.Recordset ' Connection überprüfen If ActiveConn Is Nothing Then Exit Function On Error GoTo SQLCheck_Error With oCmd ' Command initialisieren .ActiveConnection = ActiveConn .CommandType = adCmdText ' SQL-Ausführung unterdrücken .CommandText = "SET NOEXEC ON" .Execute ' SQL Syntax prüfen .CommandText = sSQL Set oRSCmd = .Execute ' SQL Ausführung wieder aktivieren .CommandText = "SET NOEXEC OFF" .Execute End With ' Command und Recodset terminieren Set oCmd = Nothing Set oRSCmd = Nothing ' Rückgabewert setzen SQLCheck = True Exit Function SQLCheck_Error: ' Syntaxfehler ausgeben MsgBox Err.Description, vbInformation ' Command terminieren If Not oCmd Is Nothing Then oCmd.CommandText = "SET NOEXEC OFF" oCmd.Execute Set oCmd = Nothing End If ' Recordset terminieren If Not oRSCmd Is Nothing Then _ Set oRSCmd = Nothing ' Rückgabewert setzen SQLCheck = False End Function Übergeben Sie der Funktion die aktive Connection zum Server und das zu prüfende Statement. Im folgenden Beispiel wird die Connection "oConn" und der Text aus der Textbox "txtSQL" überprüft. If SQLCheck(oConn, txtSQL.Text) Then MsgBox "SQL Syntax ok.", vbInformation End If Hinweis: Dieser Tipp wurde bereits 16.043 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. |
sevZIP40 Pro DLL Zippen und Unzippen wie die Profis! Mit nur wenigen Zeilen Code statten Sie Ihre Anwendungen ab sofort mit schnellen Zip- und Unzip-Funktionen aus. Hierbei lassen sich entweder einzelnen Dateien oder auch gesamte Ordner zippen bzw. entpacken. 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. |