ホームページ > データベース > mysql チュートリアル > C# SqlCommand はストアド プロシージャを使用せずに列名をパラメーター化できますか?

C# SqlCommand はストアド プロシージャを使用せずに列名をパラメーター化できますか?

Susan Sarandon
リリース: 2024-12-21 14:29:10
オリジナル
338 人が閲覧しました

Can C# SqlCommand Parameterize Column Names Without Stored Procedures?

SqlCommand のパラメーター: 列名のパラメーター化の代替

C# では、ストアド プロシージャが動的な列名のパラメーター化に常に望ましいソリューションであるとは限りません。ストアド プロシージャに頼らずにこれを実現できるでしょうか?

簡単な答えはノーです。 SqlCommand は列名のパラメータ化をサポートしていません。ただし、実行時にクエリを動的に構築できます。

インジェクション攻撃を防ぐには、入力列名 (この場合は「スロット」) が承認され、予期されるものであることを検証することが重要です。これを念頭に置いて、次のようにクエリを構築できます。

// TODO: verify that "slot" is an approved/expected value
SqlCommand command = new SqlCommand("SELECT [" + slot +
           "] FROM Users WHERE name=@name; ")
prikaz.Parameters.AddWithValue("name", name);
ログイン後にコピー

このメソッドにより、指定された列名に基づいてクエリを動的に構築しながら、「@name」などの入力値をパラメータ化できます。

以上がC# SqlCommand はストアド プロシージャを使用せずに列名をパラメーター化できますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート