重构几乎相同的 linq 查询,其中 where 子句不同
我有两种几乎相同的方法。唯一的区别是 where 子句(和方法名称)。我刚刚包含了一个简化的 linq 查询。
from tableA in db.tableA
join tableB in db.tableB on tableA.id equals tableB.id
where tableB.ref == "blah"
select tableA
吗
from tableA in db.tableA
join tableB in db.tableB on tableA.id equals tableB.id
where tableB.refb == "blah"
select tableA
有什么方法可以改变位置 ?我知道我可以从查询中删除 where ,然后在返回结果后使用 .notation 进行过滤。 (可能需要做一些其他的事情来确保返回 tableB 中我需要的字段)。
有更好的办法吗?我有两个除了 where 之外几乎相同的 linq 查询,这有什么关系吗?
I have two methods that are almost identical. The only dffernece is the where clause (and method name). I have just included a simplified linq query.
from tableA in db.tableA
join tableB in db.tableB on tableA.id equals tableB.id
where tableB.ref == "blah"
select tableA
and
from tableA in db.tableA
join tableB in db.tableB on tableA.id equals tableB.id
where tableB.refb == "blah"
select tableA
Is there a way I can make the where change? I know I could remove there where from the query then after the results are returned use .notation to filter. (May need to do some other stuff to make sure the field I need from tableB is returned).
Is there a better way? Does it matter that I have two linq queries that are almost identical apart from the where?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
是的,将其重构为这样,
这样您就可以在一个地方进行查询并仅过滤该主查询
Yes refactor it to this
This way you can you query in one palce and just filter that main query
除非性能是一个问题,否则您可以将它们保持原样。
这些看起来像是简单的查询,重构它们会降低代码的可读性。
Unless performance is a concern, you could keep them as they are now.
These look like simple queries and refactoring them would make the code less readable.