亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

將多個 tvp 值添加到數據表時出錯

將多個 tvp 值添加到數據表時出錯

C#
尚方寶劍之說 2022-11-21 16:49:49
我嘗試使用表值參數將包含多列的列表添加到 MSSQL 數據庫。我收到此錯誤:'無法將 '...Models.OptionValue' 類型的對象轉換為類型 'System.IConvertible'。無法將 <...OptionValue> 存儲在 OptionID 列中。預期類型是 Int32。InnerException:InvalidCastException:無法將“...Models.OptionValue”類型的對象轉換為類型“System.IConvertible”。SQL Tvp 表:CREATE TYPE [dbo].[OptionValueList] AS TABLE(    [OptionID] [int] NULL,    [ValueID] [int] NULL)班級:public class OptionValue {        public int OptionID { get; set; }        public int ValueID { get; set; }} public class OptionListVM {        public int ProductID { get; set; }        public List<OptionValue> OptionValueLst { get; set; } }這是我嘗試添加列以便將列表傳遞給存儲過程的地方:    DataTable tvp = new DataTable();    tvp.Columns.Add(new DataColumn("OptionID", typeof(int)));    tvp.Columns.Add(new DataColumn("ValueID", typeof(int)));    foreach (var x in o.OptionValueLst)                       tvp.Rows.Add(x); -- error line我實現了 IConvertable 接口,但它不起作用。我怎樣才能解決這個問題 ?
查看完整描述

1 回答

?
Qyouu

TA貢獻1786條經驗 獲得超11個贊

DataTable tvp = new DataTable();

tvp.Columns.Add(new DataColumn("OptionID", typeof(int)));

tvp.Columns.Add(new DataColumn("ValueID", typeof(int)));


foreach (<OptionValue>x in o.OptionValueLst) {

DataRow dr = tvp.NewRow();

dr("OptionID") = x.OptionID;

dr("ValueID") = x.ValueID; 

tvp.Rows.Add(dr); 

}


查看完整回答
反對 回復 2022-11-21
  • 1 回答
  • 0 關注
  • 119 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號