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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

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

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

Unable to cast object of type 'System.Nullable`1[System.Int16][]' to type 'System.IConvertible'


?

一段代碼99%不會(huì)出錯(cuò),0.1%會(huì)報(bào)上邊的錯(cuò),debug費(fèi)了老鼻子時(shí)間,發(fā)現(xiàn)此坑很深。異常是?cmd.ExecuteNonQuery() 拋的,實(shí)際是?para.Value = list.Select(d => d.ID).ToArray() 引起的,但是此句實(shí)在是沒毛病啊!。。。。。。。。哪?。。。。。。。。而最終原因是數(shù)據(jù)源數(shù)量為0,list.Count=0。list.Count=0的情況下,用?ArrayBind 實(shí)際本無意義了,所以解決方案是加上行判斷if(list.Count>0)。

而99%不報(bào)錯(cuò)是99%的情況下數(shù)據(jù)不為空。


?

var q = from d in db.tbl? select d;

var list = q.ToList();

if(list.Count>0)? ? ?//如果數(shù)據(jù)集為空還執(zhí)行,會(huì)報(bào) ...'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%這里報(bào)異常
cmd.Parameters.Add(para);

cmd.ExecuteNonQuery();
}

轉(zhuǎn)載于:https://www.cnblogs.com/flyGy/p/9482850.html

總結(jié)

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

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。