C# コンソール アプリを使用して AS400 データベースから結果セットを返すのに苦労しています... データベースに接続でき、AS400 ログで接続を確認しましたが、次のエラーが発生するようです。
System.InvalidCastException は処理されませんでした Message=返されたデータ型は現在、プロバイダーによってサポートされていません。Source=IBM.Data.DB2.iSeries StackTrace: at IBM.Data.DB2.iSeries.iDB2DbTypeUtility.MapSQLTypeToDCPCType(DcSqlTypes sqlType, Int32 colccsid, UInt32 length) at IBM.Data.DB2.iSeries.iDB2Command.setRowOfParameterData(MpDcData[]& dcDataRow) の IBM.Data.DB2.iSeries.iDB2Command.execute() の IBM.Data.DB2.iSeries.iDB2Command.ExecuteNonQuery() の GeacFutureDelivery.Program.Main(String[] args) の C:\Users\harlim\ documents\visual studio 2010\Projects\GeacFutureDelivery\GeacFutureDelivery\Program.cs:System.AppDomain._nExecuteAssembly(RuntimeAssembly assembly, String[] args) at System.AppDomain.ExecuteAssembly(String assemblyFile, Evidence assemblySecurity,
私の情報源は次のとおりです。
var connectionString = "<Connection String>";
int startDate = 1120530;
int endDate = 1120602;
try
{
using (var connection = new iDB2Connection(connectionString))
{
connection.Open();
iDB2Transaction trans = connection.BeginTransaction();
iDB2Command command = connection.CreateCommand();
string query = "DRLOBJ01.GETORDPCD";
command.Transaction = trans;
command.CommandType = CommandType.StoredProcedure;
command.CommandText = query;
command.CommandTimeout = 0;
command.Parameters.Add("DTSTR", iDB2DbType.iDB2Integer).Value = startDate;
command.Parameters.Add("DTEND", iDB2DbType.iDB2Integer).Value = endDate;
command.Prepare();
using (iDB2DataReader reader = command.ExecuteReader())
{
int iCUSO51 = reader.GetOrdinal("CUSO51");
int iORDN51 = reader.GetOrdinal("ORDN51");
int iDTDR51 = reader.GetOrdinal("DTDR51");
int iOPST45 = reader.GetOrdinal("OPST45");
while (reader.Read())
{
if (!string.IsNullOrEmpty(reader.GetString(iCUSO51)))
{
Console.WriteLine((string)reader[iCUSO51]);
Console.WriteLine((string)reader[iORDN51]);
Console.WriteLine((string)reader[iDTDR51]);
Console.WriteLine((string)reader[iOPST45]);
}
}
}
}
}
catch (iDB2CommErrorException ex)
{
Console.WriteLine(ex.Message);
}
}
何かご意見は?