SQL-Code-Analyse in C#
Frage: Wie verwende ich C#, um SQL-Code zu analysieren und eine Baumstruktur zu generieren? oder irgendeine andere Struktur? Der Parser sollte außerdem eine korrekte Baumstruktur der verschachtelten Struktur generieren und die Anweisungstypen zurückgeben, die durch die Knoten in der Baumstruktur dargestellt werden. Wenn ein Knoten beispielsweise eine Schleifenbedingung enthält, sollte der Knoten als „Schleifentyp“ zurückgegeben werden.
Antwort:
Für Transact-SQL (Microsoft SQL Server) können Sie den Namespace Microsoft.SqlServer.Management.SqlParser.Parser verwenden, der sich in SQL Server befindet Es wird in der enthaltenen Assembly Microsoft.SqlServer.Management.SqlParser.dll bereitgestellt und kann frei verteilt werden.
Das Folgende ist eine Beispielmethode zum Parsen von T-SQL als Zeichenfolge in eine Reihe von Token:
IEnumerable<TokenInfo> ParseSql(string sql) { ParseOptions parseOptions = new ParseOptions(); Scanner scanner = new Scanner(parseOptions); int state = 0, start, end, lastTokenEnd = -1, token; bool isPairMatch, isExecAutoParamHelp; List<TokenInfo> tokens = new List<TokenInfo>(); scanner.SetSource(sql, 0); while ((token = scanner.GetNext(ref state, out start, out end, out isPairMatch, out isExecAutoParamHelp)) != (int)Tokens.EOF) { TokenInfo tokenInfo = new TokenInfo() { Start = start, End = end, IsPairMatch = isPairMatch, IsExecAutoParamHelp = isExecAutoParamHelp, Sql = sql.Substring(start, end - start + 1), Token = (Tokens)token, }; tokens.Add(tokenInfo); lastTokenEnd = end; } return tokens; }
Beachten Sie, dass die TokenInfo-Klasse nur eine einfache Klasse mit den oben genannten Eigenschaften ist .
Token ist diese Aufzählung:
und enthält TOKEN_BEGIN, TOKEN_COMMIT, TOKEN_EXISTS und andere Konstanten.
Update: ist jetzt ein separates Nuget-Paket: [Microsoft.SqlServer.Management.SqlParser](https://www.nuget.org/packages/Microsoft.SqlServer.Management. SqlParser ).
Das obige ist der detaillierte Inhalt vonWie kann ich SQL-Code in C# analysieren und eine Baumstruktur generieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!