第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

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

數(shù)據(jù)表上的Linq查詢

數(shù)據(jù)表上的Linq查詢

開心每一天1111 2019-06-18 15:53:54
數(shù)據(jù)表上的Linq查詢我試圖對DataTable對象執(zhí)行LINQ查詢,奇怪的是,我發(fā)現(xiàn)在DataTables上執(zhí)行這樣的查詢并不簡單。例如:var results = from myRow in myDataTablewhere results.Field("RowNo") == 1select results;這是不允許的。我怎么能像這樣工作呢?我很驚訝LINQ查詢在DataTables上是不允許的!
查看完整描述

3 回答

?
烙印99

TA貢獻1829條經(jīng)驗 獲得超13個贊

您不能查詢DataTable收藏,自DataRowCollection沒有實現(xiàn)IEnumerable<T>..您需要使用AsEnumerable()延展DataTable..就像這樣:

var results = from myRow in myDataTable.AsEnumerable()where myRow.Field<int>("RowNo") == 1select myRow;

正如基思所說,你需要添加一個引用System.Data.DataSetExstance

AsEnumerable()回報IEnumerable<DataRow>..如果你需要轉(zhuǎn)換IEnumerable<DataRow>轉(zhuǎn)到DataTable,使用CopyToDataTable()分機。

下面是使用Lambda表達式查詢,

var result = myDataTable    .AsEnumerable()
    .Where(myRow => myRow.Field<int>("RowNo") == 1);


查看完整回答
反對 回復(fù) 2019-06-18
?
慕村225694

TA貢獻1880條經(jīng)驗 獲得超4個贊

var results = from DataRow myRow in myDataTable.Rows
    where (int)myRow["RowNo"] == 1
    select myRow


查看完整回答
反對 回復(fù) 2019-06-18
?
泛舟湖上清波郎朗

TA貢獻1818條經(jīng)驗 獲得超3個贊

這并不是故意不允許在DataTable上使用它們,而是因為DataTables在IQueryable和GenericIEnDigable構(gòu)造之前就可以執(zhí)行Linq查詢。

這兩個接口都需要某種類型的安全驗證。DataTable不是強類型的。例如,這也是人們不能對ArrayList進行查詢的原因。

要使Linq工作,您需要將結(jié)果映射到類型安全對象,然后對其進行查詢。


查看完整回答
反對 回復(fù) 2019-06-18
  • 3 回答
  • 0 關(guān)注
  • 492 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號