[InvalidCastException] OleDbDataReaderでGetInt32メソッドエラー(C#)
エラー内容
- OracleのDBに接続
- OleDbDataReaderで、テーブルのデータをSELECTして読み込む
- NUMBER型の列を、GetInt32()で取得しようとする
- エラー「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メソッドが多いので、そっちで使うのかもしれない。