このガイドでは、VBA マクロを使用して Excel テーブルに対して SQL クエリを直接実行する方法を説明します。 このアプローチには、ハードコードされた範囲に比べて利点があり、データが変更されても柔軟性が維持されます。
固定範囲または名前付き範囲を使用する代わりに、SQL 文字列で使用するテーブルのアドレスを動的に決定します。これにより、クエリが常に正しいデータをターゲットにすることが保証されます。 その方法は次のとおりです:
名前付き範囲のアドレスを取得するには、次を使用します。
<code class="language-vba">Sheets("shtName").Range("namedRangeName").Address</code>
これはアドレスを文字列として返します (例: $A$1:$A$8)。
シート名を含むより完全なアドレスについては、次を使用します:
<code class="language-vba">ActiveWorkbook.Names.Item("namedRangeName").RefersToLocal</code>
これにより、=Sheet1!$C$1:$C$4 形式の文字列が提供されます。 これを SQL ステートメントで使用するには:
<code class="language-vba">strRangeAddress = Mid(ActiveWorkbook.Names.Item("namedRangeName").RefersToLocal, 2) strSQL = "SELECT * FROM [" & strRangeAddress & "]"</code>
これにより、アドレス部分が抽出され、SQL クエリが構築されます。
以上がVBA マクロを使用して Excel テーブルに対して SQL クエリを実行するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。