Eclipselink @mapkey и @JoinFetch (JoinFetchType.OUTER) не могут сосуществовать? - PullRequest
1 голос
/ 21 февраля 2011

В классе сущностей Customer.java у меня был следующий код:

@OneToMany(cascade = CascadeType.ALL, mappedBy = "customer", fetch = FetchType.EAGER)
@MapKey(name = "key")
@JoinFetch(JoinFetchType.OUTER)
private Map<String, CustomerSuppInfo> suppInfoMap....

обнаружил, что когда я запрашиваю сущность клиента, SQL, сгенерированный eclipselink, не присоединяется, извлекает карту CustomerSuppInfo (она генерирует1 SQL для выбора таблицы клиентов, а затем еще 1 SQL для выбора таблицы supp_info по id) Все, что мне нужно, - это просто сгенерировать 1 SQL и выбрать все поле, связанное с клиентом, чтобы минимизировать количество сгенерированных SQL вызовов / EJB.

разве эти 2 аннотации не могут сосуществовать?Я пытался найти документацию JPA, но, похоже, не повезло: (

Ответы [ 2 ]

1 голос
/ 22 февраля 2011

Если аннотация "@JoinFetch (JoinFetchType.OUTER)" не приводит к тому, что EclipseLink присоединяется к извлечению "suppInfoMap" для всех запросов в принадлежащем объекте, и вы не переопределили это отображение с использованием XML, то это ошибка. Вы должны подать ошибку EclipseLink. В качестве альтернативы вы можете создать свой запрос на присоединение к «suppInfoMap» напрямую, используя ключевое слово JPQL «JOIN FETCH».

0 голосов
/ 21 февраля 2011

Пример вашего запроса

import java.util.HashMap; import java.util.Map;

import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; import javax.persistence.MapKey; импорт javax.persistence.OneToMany;

@ Entity общественный класс отдел { @Id @GeneratedValue (стратегии = GenerationType.IDENTITY) private int id; личное строковое имя; @OneToMany (mappedBy = "отдел") @MapKey (имя = "имя") личная карта студентов;

public Department() {
    students = new HashMap<String, Student>();
}

public int getId() {
    return id;
}

public void setId(int id) {
    this.id = id;
}

public String getName() {
    return name;
}

public void setName(String deptName) {
    this.name = deptName;
}

public void addStudent(Student student) {
    if (!getStudents().containsKey(student.getName())) {
        getStudents().put(student.getName(), student);
        if (student.getDepartment() != null) {
            student.getDepartment().getStudents().remove(student.getName());
        }
        student.setDepartment(this);
    }
}

public Map<String,Student> getStudents() {
    return students;
}

public String toString() {
    return "Department id: " + getId() + 
           ", name: " + getName();
}

}

Файл: Student.java

import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; import javax.persistence.ManyToOne;

@ Entity публичный класс Student { @Id @GeneratedValue (стратегии = GenerationType.IDENTITY) private int id; личное строковое имя;

@ManyToOne
private Department department;

public int getId() {
    return id;
}

public void setId(int id) {
    this.id = id;
}

public String getName() {
    return name;
}

public void setName(String name) {
    this.name = name;
}


public Department getDepartment() {
    return department;
}

public void setDepartment(Department department) {
    this.department = department;
}

public String toString() {
    return "Student id: " + getId() + " name: " + getName() + 
           " with " + getDepartment();
}

}

Файл: Helper.java

import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.ResultSetMetaData; import java.sql.Statement;

Публичный класс Хелпер { public static void checkData () выдает Exception { Class.forName ( "org.hsqldb.jdbcDriver"); Соединение conn = DriverManager.getConnection ("jdbc: hsqldb: data / tutorial", "sa", ""); Оператор st = conn.createStatement ();

ResultSet mrs = conn.getMetaData().getTables(null, null, null, new String[] { "TABLE" });
while (mrs.next()) {
  String tableName = mrs.getString(3);
  System.out.println("\n\n\n\nTable Name: "+ tableName);

  ResultSet rs = st.executeQuery("select * from " + tableName);
  ResultSetMetaData metadata = rs.getMetaData();
  while (rs.next()) {
    System.out.println(" Row:");
    for (int i = 0; i < metadata.getColumnCount(); i++) {
      System.out.println("    Column Name: "+ metadata.getColumnLabel(i + 1)+ ",  ");
      System.out.println("    Column Type: "+ metadata.getColumnTypeName(i + 1)+ ":  ");
      Object value = rs.getObject(i + 1);
      System.out.println("    Column Value: "+value+"\n");
    }
  }
}

} }

Файл: Main.java

import java.util.List;

import javax.persistence.EntityManager; import javax.persistence.EntityManagerFactory; импорт javax.persistence.Persistence; импорт javax.persistence.Query;

публичный класс Main { static EntityManagerFactory emf = Persistence.createEntityManagerFactory ("JPAService"); static EntityManager em = emf.createEntityManager ();

public static void main (String [] a) создает исключение { em.getTransaction () начинается ();.

Student student = new Student();
student.setName("Joe");
em.persist(student);

Department dept = new Department();
dept.addStudent(student);
em.persist(dept);

em.flush();






Query query = em.createQuery("SELECT e FROM Student e");
List<Student> list = (List<Student>) query.getResultList();
System.out.println(list);

query = em.createQuery("SELECT d FROM Department d");
List<Department> dList = (List<Department>) query.getResultList();
System.out.println(dList);

em.getTransaction().commit();
em.close();
emf.close();

Helper.checkData();

} }

Файл: persistence.xml

http://java.sun.com/xml/ns/persistence/persistence" version = "1.0">

...