如何将 linq 查询转换为 SQL 查询?

Posted

技术标签:

【中文标题】如何将 linq 查询转换为 SQL 查询?【英文标题】:How convert linq query to SQL query? 【发布时间】:2020-07-19 08:22:13 【问题描述】:

我想将以下 LINQ 查询转换为 SQL 查询。

var ACTIVITY_ROYALITY_MONTH = from m in db.MiningPermit
                                      join pm in db.Permit_Mineral on m.MINING_PERMIT_ID equals pm.MINING_PERMIT_ID
                                      join r in db.Royality on pm.Permit_Minerals_ID equals r.Permit_Minerals_ID
                                      where r.ORDER_ID == 0 // NULL in server
                                      orderby r.YEAR, r.MONTH
                                      group r by new  m.MINING_PERMIT_ID , r.YEAR, r.MONTH   into mpmr
                                      select mpmr.ToList();

【问题讨论】:

到目前为止你尝试了什么? 您可以查看正在执行的实际查询。查看此内容以了解如何查看 SQL 查询 ***.com/questions/11002573/… 这是一个糟糕的 LINQ 查询 - LINQ 不能替代 SQL,并且 JOIN 是由 EF 或 L2S 基于上下文关系生成的。它所做的也不是它看起来的样子 - 您无法使用 GROUP BY 并在没有聚合的情况下返回 any 非组列。这真正做的是连接一些表并返回所有行和列。您可以按原样复制它,将SELECT * 放在顶部并删除GROUP BY 子句 【参考方案1】:

使用Linqpad 并在 C# 查询中重新创建 linq(甚至通过引入您的程序集)。运行查询。然后在输出中,有一个SQL的选择按钮,会显示sql代码。

【讨论】:

以上是关于如何将 linq 查询转换为 SQL 查询?的主要内容,如果未能解决你的问题,请参考以下文章

如何将SQL查询转换为LINQ?

如何将此 SQL 内部联接查询转换为 LINQ 语法?

如何将此 GROUP BY / MIN SQL 查询转换为 LINQ?

如何将带有内连接的 sql 查询转换为 linq lambda 表达式?

如何将以下 linq 查询转换为 SQL 中的 (Having)

将 sql 查询转换为 linq 查询