Nhibernate HQL到SQL转换器
有人知道如何将NHibernate HQL转换为SQL脚本吗?由于HQL转换取决于您的映射和运行时行为,我认为不太可能有一种静态转换方法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 =
您可以针对真实数据库运行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"> </span>
</div>
<br>
<div style="border:2px solid green">
Ваш запрос на SQL:
<br/><br/><span role="SQL"> </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();
}