Unable to cast object of type 'System.Nullable`1[System.Int16][]' to type 'System.IConvertible'
?
一段代碼99%不會出錯,0.1%會報上邊的錯,debug費了老鼻子時間,發現此坑很深。異常是?cmd.ExecuteNonQuery() 拋的,實際是?para.Value = list.Select(d => d.ID).ToArray() 引起的,但是此句實在是沒毛病啊!。。。。。。。。哪?。。。。。。。。而最終原因是數據源數量為0,list.Count=0。list.Count=0的情況下,用?ArrayBind 實際本無意義了,所以解決方案是加上行判斷if(list.Count>0)。
而99%不報錯是99%的情況下數據不為空。
?
var q = from d in db.tbl? select d;
var list = q.ToList();
if(list.Count>0)? ? ?//如果數據集為空還執行,會報 ...'System.IConvertible' 的異常
{
var cmd =...
cmd.ArrayBindCount = list.Count();
cmd.BindByName = true;
var para = new Oracle.ManagedDataAccess.Client.OracleParameter();
para.ParameterName = "ID";
para.OracleDbTypeEx = Oracle.ManagedDataAccess.Client.OracleDbType.NVarchar2;
para.Direction = System.Data.ParameterDirection.Input;
para.Value = list.Select(d => d.ID).ToArray();? ? ?//0.1%這里報異常
cmd.Parameters.Add(para);
cmd.ExecuteNonQuery();
}