我正在努力使用 C# 控制台应用程序从 AS400 数据库返回结果集...我可以连接到数据库并且我已经通过 AS400 日志验证了连接但是我似乎遇到了以下错误:
System.InvalidCastException 未处理 Message=提供者当前不支持返回的数据类型。Source=IBM.Data.DB2.iSeries StackTrace:在 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\文档\visual studio 2010\Projects\GeacFutureDelivery\GeacFutureDelivery\Program.cs:System.AppDomain._nExecuteAssembly 的第 40 行(RuntimeAssembly 程序集,String[] args)在 System.AppDomain.ExecuteAssembly(字符串 assemblyFile,证据 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);
}
}
有什么想法吗?