質問:
C# で SQL コードを解析して、コードの構文を表し、各ノードが表すステートメントの種類に関する情報を含むツリー構造を生成するにはどうすればよいですか?
答え:
Microsoft.SqlServer.Management.SqlParser.Parser 名前空間
Transact-SQL (Microsoft SQL Server) の場合、Microsoft.SqlServer.Management.SqlParser.Parser 名前空間は強力な解析ソリューションを提供します。 T-SQL 文字列をトークンのシーケンスに解析するメソッドの例を次に示します。
<code class="language-csharp">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; }</code>
注:
TokenInfo
Tokens
、TOKEN_BEGIN
など) を表す定数を含む列挙です。 TOKEN_COMMIT
重要なヒント:
Microsoft.SqlServer.Management.SqlParser アセンブリは、https://www.php.cn/link/e6e8bbe351bf19f963820a96543f25db から別の NuGet パッケージとして利用できるようになりました。
以上がC# で SQL コードを解析して構文ツリーを作成するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。