日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

ODP 使用 ArrayBind 时可能会遇到的巨坑 'System.IConvertible' 的解决方法

發布時間:2023/12/18 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 ODP 使用 ArrayBind 时可能会遇到的巨坑 'System.IConvertible' 的解决方法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

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();
}

轉載于:https://www.cnblogs.com/flyGy/p/9482850.html

總結

以上是生活随笔為你收集整理的ODP 使用 ArrayBind 时可能会遇到的巨坑 'System.IConvertible' 的解决方法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。