Вопрос

Если я хочу обыскать тех студентов, которые посещают занятия "Математика" и "Джон" - это его группа:

должен ли я использовать 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"));

как поместить subquery1 и subquery2 вместе с начальными критериями?

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?Я думаю, что лодки те же самые...

Это было полезно?

Решение

createAlias и createCriteria - это идентичный в текущих версиях Hibernate и NHibernate.Единственное отличие заключается в том, что createCriteria имеет 2 дополнительные перегрузки без параметра alias.

Предположительно, они отличались в более старой версии, но какие-либо различия давно исчезли.

Псевдоним может быть определен в терминах другого псевдонима, поэтому ваш первый пример можно записать как:

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

Другие советы

Добавление к ответу Ксавьержоа:

На самом деле существует довольно большая разница между двумя методами, которые вы заметите, если цепь 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

Пожалуйста, обратитесь к следующему исходному коду из 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;
}
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top