Nhibernate HQL到SQL转换器

Nhibernate HQL到SQL转换器,nhibernate,hql,Nhibernate,Hql,有人知道如何将NHibernate HQL转换为SQL脚本吗?由于HQL转换取决于您的映射和运行时行为,我认为不太可能有一种静态转换方法 您可以针对真实数据库运行HQL,并通过特定rdbms或NHProf的探查器捕获生成的SQL 我对所有参数都不熟悉,但这似乎有效: ISessionFactory sessionFactory = ... var sf = (SessionFactoryImpl) sessionFactory; var hql = "from Person"; var qt =

有人知道如何将NHibernate HQL转换为SQL脚本吗?

由于HQL转换取决于您的映射和运行时行为,我认为不太可能有一种静态转换方法


您可以针对真实数据库运行HQL,并通过特定rdbms或NHProf的探查器捕获生成的SQL

我对所有参数都不熟悉,但这似乎有效:

ISessionFactory sessionFactory = ...
var sf = (SessionFactoryImpl) sessionFactory;
var hql = "from Person";
var qt = sf.Settings.QueryTranslatorFactory.CreateQueryTranslator("", hql, new Dictionary<string, IFilter>(), (ISessionFactoryImplementor) sessionFactory);
qt.Compile(new Dictionary<string, string>(), true);
var sql = qt.SQLString;
Console.WriteLine(sql);
ISessionFactory会话工厂=。。。
var sf=(SessionFactoryImpl)sessionFactory;
var hql=“来自个人”;
var qt=sf.Settings.QueryTranslatorFactory.CreateQueryTranslator(“”,hql,new Dictionary(),(ISessionFactoryImplementor)sessionFactory);
Compile(newdictionary(),true);
var sql=qt.SQLString;
Console.WriteLine(sql);

我不确定动态地将HQL自动转换为SQL的值是多少

你到底想通过这个来实现什么


最简单的方法是在运行SQLServer探查器的同时运行代码,以查看生成的SQL。但更好的方法是下载nhProf(www.nhProf.com)并将其与代码一起使用。您将能够准确地看到您的代码在SQL中输出的内容,它将对其进行格式化和颜色编码,并为您提供有关改进nhibernate使用情况的提示。

对于nhibernate 3.2,这似乎是从HQL查询中获取SQL的最简单方法:

private string GetSQL(string hql)
{
    using (var iSession = ...)
    {
        var session = (NHibernate.Engine.ISessionImplementor)iSession;
        var sf = (NHibernate.Engine.ISessionFactoryImplementor)iSession.SessionFactory;

        var sql = new NHibernate.Engine.Query.HQLStringQueryPlan(hql, true, session.EnabledFilters, sf);

        return string.Join(";", sql.SqlStrings);
    }
}

我以前的训练。那是测试版。给你!(hql2sql.jsp)


$(文档).ready(函数(){
$('span[role=“HQL”]”)。文本(“”);
$('span[role=“SQL”]”)。文本(“”);
});
азааПаааааааHQL:



азааааааааааааааааа


以下是如何使用NH 5.2(请参阅)


我正在使用MYSQL和NHProf。但它生成的SQL不能针对数据库执行。在表1(第1列,第2列,第3列,第4列,第5列)中插入值(?,,,,,,,?,?)好吧,这只是一个参数化查询,在上面的某个地方必须是参数声明和初始化。我非常确定NHProf支持复制和粘贴SQL。否则,请在此询问:
<SCRIPT type="text/javascript">
    <%  
        org.hibernate.Session ThisSession = SessionFactory.getSession();
        org.hibernate.engine.SessionImplementor ThisSessionImplementor = (org.hibernate.engine.SessionImplementor) ThisSession;
        org.hibernate.engine.SessionFactoryImplementor ThisSessionFactory = (org.hibernate.engine.SessionFactoryImplementor) ThisSession.getSessionFactory();
        String HQL_Query = "SELECT ... ";
        String SQL_Query;
        try{
            org.hibernate.engine.query.HQLQueryPlan HQL_Query_Plan = new org.hibernate.engine.query.HQLQueryPlan(HQL_Query, true, ThisSessionImplementor.getEnabledFilters(), ThisSessionFactory);
            SQL_Query = org.apache.commons.lang.StringUtils.join(HQL_Query_Plan.getSqlStrings(), ";");
        }catch(Exception e){SQL_Query = "ERROR!!  ::  " + e.getMessage();}
    %>
    $(document).ready(function(){
        $('span[role="HQL"]').text(" <%=HQL_Query%>");
        $('span[role="SQL"]').text(" <%=SQL_Query%>");
    });
</SCRIPT>
<div style="border:2px solid brown">
    Ваш запрос на HQL:
    <br/><br/><span role="HQL">&nbsp;</span>
</div>
<br>
<div style="border:2px solid green">
    Ваш запрос на SQL:
    <br/><br/><span role="SQL">&nbsp;</span>
</div>
public static string HqlToSql(string hql, ISession session)
{
    var sessionImp = (ISessionImplementor)session;
    var translatorFactory = new ASTQueryTranslatorFactory();
    var translators = translatorFactory.CreateQueryTranslators(new NHibernate.Hql.StringQueryExpression(hql),
         null, false, sessionImp.EnabledFilters, sessionImp.Factory);
    var hqlSqlGenerator = new HqlSqlGenerator(((QueryTranslatorImpl)translators[0]).SqlAST, sessionImp.Factory);
    hqlSqlGenerator.Generate();
    return hqlSqlGenerator.Sql.ToString();
}