これはおそらく、ID のリストを使用して Dapper で多数の行をクエリする最速の方法です。これは、あなたが考えることができる他のほとんどの方法よりも高速であることを約束します(別の回答で与えられたようにTVPを使用することを除いて、私はテストしていませんが、まだデータを入力する必要があるため、遅くなる可能性がありますTVP)。これは 、構文を使用する Dapper よりもはるかに高速であり、行ごとに Entity Framework よりも高速です。また、 orのリストを渡すよりもはるかに高速です。複数列キーを使用するように簡単に拡張できます。余分な列を、一時テーブル、および結合条件に追加するだけです。IN
VALUES
UNION ALL SELECT
DataTable
public IReadOnlyCollection<Item> GetItemsByItemIds(IEnumerable<int> items) {
var itemList = new HashSet(items);
if (itemList.Count == 0) { return Enumerable.Empty<Item>().ToList().AsReadOnly(); }
var itemDataTable = new DataTable();
itemDataTable.Columns.Add("ItemId", typeof(int));
itemList.ForEach(itemid => itemDataTable.Rows.Add(itemid));
using (SqlConnection conn = GetConnection()) // however you get a connection
using (var transaction = conn.BeginTransaction()) {
conn.Execute(
"CREATE TABLE #Items (ItemId int NOT NULL PRIMARY KEY CLUSTERED);",
transaction: transaction
);
new SqlBulkCopy(conn, SqlBulkCopyOptions.Default, transaction) {
DestinationTableName = "#Items",
BulkCopyTimeout = 3600 // ridiculously large
}
.WriteToServer(itemDataTable);
var result = conn
.Query<Item>(@"
SELECT i.ItemId, i.ItemName
FROM #Items x INNER JOIN dbo.Items i ON x.ItemId = i.ItemId
DROP TABLE #Items;",
transaction: transaction,
commandTimeout: 3600
)
.ToList()
.AsReadOnly();
transaction.Rollback(); // Or commit if you like
return result;
}
}
一括挿入について少し学ぶ必要があることに注意してください。トリガーの起動 (デフォルトは no)、制約の尊重、テーブルのロック、同時挿入の許可などに関するオプションがあります。