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

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

如何從 SQL 查詢中獲取“帶有數據的模型”列表?

如何從 SQL 查詢中獲取“帶有數據的模型”列表?

C#
智慧大石 2023-08-13 16:11:37
嘿我有這樣的代碼它從讀者返回模型列表。我怎樣才能做得更好?不要使用這個address.Add(new Address {    ID = (int) reader["ID"],    Address = reader["Address"].ToString(),    PhoneNumber = (int) reader["PhoneNumber"]});但使用更多這樣的address.Add(new Address(reader?or somthing else));,或者也許如果我可以不使用列表并返回數據,僅在它返回的類中我可以添加到可觀察集合?    public async Task<IEnumerable<Address>> LoadDetail(int id)    {        await conn.OpenAsync();        List<Address> address = new List<Address>();        using (SqlCommand command = conn.CreateCommand())        {            command.CommandText = $"SELECT * FROM Address WHERE ID = {id}";,            using (SqlDataReader reader = command.ExecuteReader())            {                while (await reader.ReadAsync())                {                    address.Add(new Address { ID = (int)reader["ID"], Address = reader["Address"].ToString(), PhoneNumber = (int)reader["PhoneNumber"] });                }            }        }        return address;    }
查看完整描述

1 回答

?
LEATH

TA貢獻1936條經驗 獲得超7個贊

如果不需要異步代碼,您可以避免創建列表并編寫以下內容:


while (reader.Read())

{

    yield return new Address { ID = (int)reader["ID"], Address = reader["Address"].ToString(), PhoneNumber = (int)reader["PhoneNumber"] };

}

您可以通過讀者的擴展方法來改進它:


yield return reader.GetAddress();


public static class ReaderExtensions

{

    public static Address GetAddress(this SqlDataReader reader)

    {

        return new Address { ID = (int)reader["ID"], Address = reader["Address"].ToString(), PhoneNumber = (int)reader["PhoneNumber"] };

    {

}


查看完整回答
反對 回復 2023-08-13
  • 1 回答
  • 0 關注
  • 140 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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