【问题标题】:NHibernate HQL Inner Join (SQL Server,Visual C#)NHibernate HQL 内连接 (SQL Server,Visual C#)
【发布时间】:2015-05-30 14:10:05
【问题描述】:

我想将 HQL 与内部联接一起使用。但是,会引发查询语法异常。

这是我的 C# 代码:

string sqlQuery = "Select fq FROM Answers as fq INNER JOIN Questions as q " +
    " on fq.questionId=q.questionId";

IList Result;
int count = 0;

try
{
    using (ISession session = ConnectionModule.OpenSession())
    {
        IQuery query = session.CreateQuery(sqlQuery);
        session.CreateCriteria(typeof(Answers));
        Result = query.List();
    }
}
catch(Exception ex) 
{
    MessageBox.Show(ex.Message+"\n"+ex.InnerException);
}

【问题讨论】:

  • 你能粘贴显示的异常吗?
  • 不确定是否是问题所在,但您至少可以尝试更改别名:“Select fq FROM Answers as a INNER ...”如果 fq 是列,或者“Select * FROM Answers as fq INNER ...”如果你想要来自“fq”的东西。你只是不能“选择”一个表。

标签: c# sql-server nhibernate fluent-nhibernate hql


【解决方案1】:

这里的重点是

  • 如果没有映射关系,则进行交叉连接,
  • 加入现有(映射)关系。

所以,如果没有映射关系 QuestionAnswer - 我们仍然可以像这样查询它:

// instead of INNER JOIN we use 'comma' to produce CROSS JOIN
// instead of ON we need WHERE
// string sqlQuery = "Select fq FROM Answers as fq, INNER JOIN Questions as q "+ 
//  "on fq.questionId=q.questionId";

string sqlQuery = "Select fq FROM Answers as fq, Questions as q " +
    " WHERE fq.questionId=q.questionId";

如果我们有映射 Answer.QuestionIList<Answer> Question.Answers

// the Reference (C#) is the way how to express ON
string sqlQuery = "Select fq FROM Answers as fq INNER JOIN fq.Questions as q";

检查

【讨论】:

  • 不幸学习了。错误是“查询语法异常”我想做的事实;表 1= Questions(questionId,question), Table2=Answers(answerId,questionId,answer) Sql Query="select q.question,a.answer from Questions as q inner join Answers as a on q.questionId=a.questionId"
  • 您尝试过我向您展示的内容吗?大多数情况下,十字架与 WHERE 连接?尝试按照我的回答和链接......不管你信不信,这应该会给你你需要的结果......
  • 看来你终于成功了……那真是太棒了! ;) 享受强大的 NHibernate,先生
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2013-10-14
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多