In this article, I will show the most performant way to write queries for a collection of objects in .Net Core. The article discusses the common methods of LINQ and their comparison. After reading this article, you may have to review your project code!
Comparisons were made between query syntax, called LINQ, and method syntax called LAMBDA.
💡 Connect with me on LinkedIn: https://www.linkedin.com/in/hussein-nm/
✨ Where()
LINQ_Where (Method name):
data:image/s3,"s3://crabby-images/450b7/450b7f23a1afc0ea078b5905500c4fc5cf20744e" alt=""
LAMBDA_Where:
data:image/s3,"s3://crabby-images/03b6a/03b6a5ab1461c79f65a33ebbb630f4682d2aa3ef" alt=""
🚀 Performance
data:image/s3,"s3://crabby-images/602de/602dee078e3cc40153fe7cd9fc4593af789fec4a" alt=""
Which one do you think is faster?
In this simple performance query, both methods are similar.
✨ Any()
LINQ_Any:
data:image/s3,"s3://crabby-images/f90a7/f90a70880be128db78286c9d2ea1613e585f1ca2" alt=""
LAMBDA_Where_Any:
data:image/s3,"s3://crabby-images/35bf8/35bf8e5c86b32f28e5c85dda1ee4c5b83d48bdc8" alt=""
LAMBDA_Any:
data:image/s3,"s3://crabby-images/23bdc/23bdcf75b456283c7f2c389af431f334cd4d6614" alt=""
🚀 Performance
data:image/s3,"s3://crabby-images/49bf1/49bf168a218685896aa9833cc774be7e222873d1" alt=""
Using Any() as the LAMBDA_Any method is faster.
✨ First()
LINQ_First:
data:image/s3,"s3://crabby-images/5ee47/5ee47313dd91fd266191fc38851d4c9ddd3e2770" alt=""
LAMBDA_Where_First:
data:image/s3,"s3://crabby-images/3b454/3b4547fe4cb063521a70532893e33ef9d189f4a4" alt=""
LAMBDA_First:
data:image/s3,"s3://crabby-images/f2040/f204048cc6e7ff0fa5c6b0aa04d5c238a41a5141" alt=""
🚀 Performance
data:image/s3,"s3://crabby-images/a40b7/a40b7ef36a6d89343d340aef2950752cb8a78ba0" alt=""
Using First() as the method a LAMBDA call is faster.
✨ FirstOrDefault()
LINQ_FirstOrDefault:
data:image/s3,"s3://crabby-images/ea12c/ea12c4e3da0f4d7470c18d5dd0e151364f3d594c" alt=""
LAMBDA_Where_FirstOrDefault:
data:image/s3,"s3://crabby-images/47eb5/47eb510e0ec67605461c3e6d504a7ec0027f8e63" alt=""
LAMBDA_FirstOrDefault:
data:image/s3,"s3://crabby-images/442d4/442d493b94a6e733bb09a9153335c5e2908d9b5e" alt=""
🚀 Performance
data:image/s3,"s3://crabby-images/17b84/17b840760a3a1338634cdae28c8b1b8b9d0bf8ea" alt=""
Using FirstOrDefault() as the method a LAMBDA call is faster.
✨ Last()
LINQ_Last:
data:image/s3,"s3://crabby-images/faa3e/faa3ee0c9ae6c1d1399c2126b80aedf4d4849c0d" alt=""
LAMBDA_Where_Last:
data:image/s3,"s3://crabby-images/d0513/d0513aea48a932bd074d5beafba54a19142ea966" alt=""
LAMBDA_Last:
data:image/s3,"s3://crabby-images/ca9a3/ca9a30204bfb7d27d12728bd06ca23c79c699e2c" alt=""
🚀 Performance
data:image/s3,"s3://crabby-images/df667/df667b995668e2609b6e0a78f7fbb70864f79583" alt=""
Using Last() as the method a LAMBDA call is faster.
✨ LastOrDefault()
LINQ_LastOrDefault:
data:image/s3,"s3://crabby-images/855cb/855cbd2fb0de4667993aa806ac984f3c1f7d8dc8" alt=""
LAMBDA_Where_LastOrDefault:
data:image/s3,"s3://crabby-images/7541b/7541b47ac490c4191afa3974883e44ba9f203f68" alt=""
LAMBDA_LastOrDefault:
data:image/s3,"s3://crabby-images/f46ab/f46ab08621663ed04a7c08560c0f48b08ff29194" alt=""
🚀 Performance
data:image/s3,"s3://crabby-images/340af/340affa06d20eaaf4ab5a82b292e402248d97867" alt=""
Using LastOrDefault() as the method a LAMBDA call is faster.
Conclusion
As shown in this article, you should always use Any(), First(), FirstOrDefault(), Last(), LastOrDefault, or Where() at the beginning of a LAMBDA statement.
data:image/s3,"s3://crabby-images/d2a4b/d2a4b5b95a60956bf167116713b36704b6670173" alt=""