Hibernate - createCriteria или createAlias?
Если я хочу искать тех студентов, которые принимают класс "Math", а "John" - его группа:
shoud Я использую createCriteria или createAlias?
Criteria:
Criteria criteria = session.createCriteria(Student.class);
Criteria subquery1 = criteria.createCriteria("courses", course).add(Restrictions.eq(course.name, "Math"));
Criteria subquery2 = criteria.createCriteria("group", student).add(Restrictions.eq(student.name, "John"));
как поставить подзапрос1 и подзапрос2 вместе с начальными критериями?
Alias:
Criteria criteria = session.createCriteria(Student.class).
createAlias("courses", course).add(Restrictions.eq(course.name, "Math")).
createCriteria("group", student).add(Restrictions.eq(student.name, "John"));
Когда использовать createCriteria и когда createAlias? Я думаю, что кайф тот же...
Ответы
Ответ 1
CreateAlias и CreateCriteria идентичны в текущих версиях Hibernate и NHibernate. Единственное отличие состоит в том, что CreateCriteria имеет 2 дополнительных перегрузки без параметра псевдонима.
Предположительно, они были разными в более старой версии, но любые различия давно прошли.
Псевдоним может быть определен в терминах другого псевдонима, поэтому ваш первый пример может быть записан как:
// Java
Criteria criteria = session.createCriteria(Student.class)
.createAlias("courses", "course")
.createAlias("course.group", "student")
.add(Restrictions.eq("course.name", "Math"))
.add(Restrictions.eq("student.name", "John"));
// C#
ICriteria criteria = session.CreateCriteria<Student>()
.CreateAlias("Courses", "course")
.CreateAlias("course.Group", "student")
.Add(Restrictions.Eq("course.Name", "Math"))
.Add(Restrictions.Eq("student.Name", "John"));
Ответ 2
Обратитесь к следующему исходному коду из Hibernate
public Criteria createCriteria(String associationPath, String alias, int joinType) {
return new Subcriteria( this, associationPath, alias, joinType );
}
public Criteria createAlias(String associationPath, String alias, int joinType) {
new Subcriteria( this, associationPath, alias, joinType );
return this;
}
Ответ 3
Добавление к xavierzhoa ответ:
На самом деле существует довольно большая разница между двумя методами, которые вы заметите, если вы связываете методы Criteria
. Вы будете продолжать работать с исходным объектом Criteria
при использовании createAlias
, тогда как при использовании createCriteria
вы работаете с более вложенной областью.
Рассмотрим это:
Criteria c = getSession()
.createCriteria(YourEntity.class)
.createCriteria("someMember", "s")
.add(Restrictions.eq("name", someArgument)); // checks YourEntity.someMember.name
против
Criteria c = getSession()
.createCriteria(YourEntity.class)
.createAlias("someMember", "s")
.add(Restrictions.eq("name", someArgument)); // checks YourEntity.name
Однако, если вы всегда назначаете и используете псевдоним, вы сможете обойти эту разницу. Как:
Criteria c = getSession()
.createCriteria(YourEntity.class, "y")
.createAlias("someMember", "s")
.add(Restrictions.eq("y.name", someArgument)); // no more confusion