スポンサーリンク

[InvalidCastException] OleDbDataReaderでGetInt32メソッドエラー(C#)

[InvalidCastException] OleDbDataReaderでGetInt32メソッドエラー(C#)

エラー内容

  1. OracleのDBに接続
  2. OleDbDataReaderで、テーブルのデータをSELECTして読み込む
  3. NUMBER型の列を、GetInt32()で取得しようとする
  4. エラー「System.InvalidCastException: 指定されたキャストは有効ではありません。」

ソースコード

static void Main(string[] args)
{
    using (OleDbConnection connection = new OleDbConnection("Provider=OraOLEDB.Oracle;User ID=TEST;Password=TEST;Data Source=XEPDB1;"))
    {
        OleDbCommand command = new OleDbCommand("SELECT AGE FROM EMP", connection);
        connection.Open();

        using (OleDbDataReader reader = command.ExecuteReader())
        {
            while (reader.Read())
            {
                int count = reader.GetInt32(0);
            }
        }
    }
}

エラーの原因

色々試してみましたが原因は不明。
もしかすると、OracleでこのGetInt32()とかの取得方法はできないかも。
SQL Serverのデータ型に合ったgetメソッドが多いので、そっちで使うのかもしれない。

C#
スポンサーリンク
シェアする
trelab