結(jié)果匿名

2022-04-21 09:44 更新

描述

可以使用擴展方法執(zhí)行查詢并使用動態(tài)類型映射結(jié)果。

匿名類型結(jié)果可以從以下擴展方法映射:

  • Query
  • QueryFirst
  • QueryFirstOrDefault
  • QuerySingle
  • QuerySingleOrDefault

這些擴展方法可以從IDbConnection類型的任意對象中調(diào)用。

案例 - Query

Query方法可以執(zhí)行查詢并將結(jié)果映射到動態(tài)類型列表。

string sql = "SELECT * FROM Invoice;";

using (var connection = My.ConnectionFactory())
{
    connection.Open();

    var invoices = connection.Query(sql).ToList();
}

案例 - QueryFirst

QueryFirst方法可以執(zhí)行查詢并將第一個結(jié)果映射到動態(tài)類型列表。

string sql = "SELECT * FROM Invoice WHERE InvoiceID = @InvoiceID;";

using (var connection = My.ConnectionFactory())
{
    connection.Open();

    var invoice = connection.QueryFirst(sql, new {InvoiceID = 1});
}

案例 - QueryFirstOrDefault

QueryFirstOrDefault方法可以執(zhí)行查詢并將第一個結(jié)果映射到動態(tài)類型列表,如果序列不包含任何元素則為默認值。

string sql = "SELECT * FROM Invoice WHERE InvoiceID = @InvoiceID;";

using (var connection = My.ConnectionFactory())
{
    connection.Open();

    var invoice = connection.QueryFirstOrDefault(sql, new {InvoiceID = 1});
}

案例 - QuerySingle

QuerySingle方法可以執(zhí)行查詢并將第一個結(jié)果映射到動態(tài)類型列表,如果序列中沒有元素則會引發(fā)異常。

string sql = "SELECT * FROM Invoice WHERE InvoiceID = @InvoiceID;";

using (var connection = My.ConnectionFactory())
{
    connection.Open();

    var invoice = connection.QuerySingle(sql, new {InvoiceID = 1});
}

案例 - QuerySingleOrDefault

QuerySingleOrDefault方法可以執(zhí)行查詢并將第一個結(jié)果映射到動態(tài)類型列表,如果序列為空則為默認值;如果序列中有多個元素,則此方法將引發(fā)異常。

string sql = "SELECT * FROM Invoice WHERE InvoiceID = @InvoiceID;";

using (var connection = My.ConnectionFactory())
{
    connection.Open();

    var invoice = connection.QuerySingleOrDefault(sql, new {InvoiceID = 1});
}


以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號