HQL转SQL转换器

5

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

6个回答

2

由于HQL翻译取决于您的映射以及运行时行为,我认为静态地进行翻译是不太可能的。

您可以针对实际数据库运行HQL,并通过特定关系型数据库的分析器或NHProf捕获生成的SQL。


我正在使用MYSQL和NHProf。但是它生成的SQL无法在数据库中执行。 插入到Table1 (Column1,Column2,Column3,Column4,Column5) 值(?,?,?,?,?) - ranj
好的,这只是一个参数化查询,在上面肯定有参数声明和初始化。我很确定NHProf支持复制和粘贴SQL。否则,请在此处提问:http://groups.google.com/group/nhprof - Johannes Rudolph

1

我的旧训练。那是测试版本。这里它!(hql2sql.jsp)

<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>

0

使用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);
    }
}

0

我不熟悉所有的参数,但这似乎可以工作:

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);

0

以下是使用 NH 5.2 的方法(请参见 https://dev59.com/CWgv5IYBdhLWcg3wTvA-#55542462

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();
}

0

我不确定动态自动转换HQL为SQL的价值是什么...

你到底想通过这个做什么?

最简单的方法是在运行SQL Server Profiler时运行代码,以查看生成的SQL。但更好的方法是下载nhProf(www.nhprof.com)并将其与您的代码一起使用。您将能够准确地看到您的代码输出的SQL,并且它将格式化和着色它,并为您提供有关改进nhibernate使用方式的提示。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接