ホームページ >データベース >mysql チュートリアル >C# を使用した MySQL でパラメータ化されたクエリを使用するときに IndexOutOfBoundsException を修正する方法

C# を使用した MySQL でパラメータ化されたクエリを使用するときに IndexOutOfBoundsException を修正する方法

DDD
DDDオリジナル
2024-12-22 16:54:12177ブラウズ

How to Fix IndexOutOfBoundsException When Using Parameterized Queries in MySQL with C#?

C# を使用した MySQL のパラメータ化されたクエリ エラーのトラブルシューティング

C# を使用した MySQL でパラメータ化されたクエリを使用する場合、次のような一般的な落とし穴を回避することが重要です。エラーに。頻繁に発生するこのような問題の 1 つは、最初のパラメーターを追加するときに発生する IndexOutOfBoundsException です。

問題:

次の簡略化されたコード スニペットを考えてみましょう:

private String readCommand = "SELECT LEVEL FROM USERS WHERE VAL_1 = ? AND VAL_2 = ?;";

public bool read(string id)
{
    MySqlCommand m = new MySqlCommand(readCommand);
    m.Parameters.Add(new MySqlParameter("", val1));
    m.Parameters.Add(new MySqlParameter("", val2));
}

このコードを実行すると、最初のパラメータ(インデックス)を追加しようとするとエラーが発生します0).

解決策:

この問題を解決するには、パラメーター化されたクエリを定義するための正しい構文は、疑問符 (?) の代わりに名前付きパラメーターを使用することです。名前付きパラメーターはより堅牢で、番号付きプレースホルダー インデックスによって引き起こされる混乱を排除します。

private String readCommand = "SELECT LEVEL FROM USERS WHERE VAL_1 = @param_val_1 AND VAL_2 = @param_val_2;";

public bool read(string id)
{
    MySqlCommand m = new MySqlCommand(readCommand);
    m.Parameters.AddWithValue("@param_val_1", val1);
    m.Parameters.AddWithValue("@param_val_2", val2);
}

さらに、ExecuteScalar メソッドを使用してクエリから単一の値をフェッチすることでコードを簡素化することをお勧めします。これにより、データ リーダーを反復処理する必要がなくなり、結果が目的のデータ型 (この場合は整数) に直接変換されます。

public bool read(string id)
{
    MySqlCommand m = new MySqlCommand(readCommand);
    m.Parameters.AddWithValue("@param_val_1", val1);
    m.Parameters.AddWithValue("@param_val_2", val2);
    level = Convert.ToInt32(m.ExecuteScalar());
    return true;
}

これらのベスト プラクティスを採用することで、IndexOutOfBoundsException とC# を使用して MySQL データベースでパラメータ化されたクエリを確実に実行できるようにします。

以上がC# を使用した MySQL でパラメータ化されたクエリを使用するときに IndexOutOfBoundsException を修正する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。