mirror of https://github.com/apache/openjpa.git
OPENJPA-1536: fix the where clause in sql generation problem when join table strategy is used in toOne eager fetch
git-svn-id: https://svn.apache.org/repos/asf/openjpa/trunk@916106 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
be33af366c
commit
ea49b4cc6a
|
@ -141,10 +141,10 @@ public abstract class InValueDiscriminatorStrategy
|
||||||
Column col = disc.getColumns()[0];
|
Column col = disc.getColumns()[0];
|
||||||
SQLBuffer sql = new SQLBuffer(sel.getConfiguration().
|
SQLBuffer sql = new SQLBuffer(sel.getConfiguration().
|
||||||
getDBDictionaryInstance());
|
getDBDictionaryInstance());
|
||||||
|
String alias = sel.getColumnAlias(col, joins);
|
||||||
boolean outer = joins != null && joins.isOuter();
|
boolean outer = joins != null && joins.isOuter();
|
||||||
if (outer)
|
if (outer)
|
||||||
sql.append("(");
|
sql.append("(");
|
||||||
String alias = sel.getColumnAlias(col, joins);
|
|
||||||
sql.append(alias);
|
sql.append(alias);
|
||||||
|
|
||||||
// if not selecting subclasses, limit to just the given class
|
// if not selecting subclasses, limit to just the given class
|
||||||
|
|
|
@ -0,0 +1,87 @@
|
||||||
|
/*
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
* or more contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. The ASF licenses this file
|
||||||
|
* to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance
|
||||||
|
* with the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing,
|
||||||
|
* software distributed under the License is distributed on an
|
||||||
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
* KIND, either express or implied. See the License for the
|
||||||
|
* specific language governing permissions and limitations
|
||||||
|
* under the License.
|
||||||
|
*/
|
||||||
|
package org.apache.openjpa.persistence.inheritance;
|
||||||
|
|
||||||
|
import javax.persistence.EntityManager;
|
||||||
|
|
||||||
|
import org.apache.openjpa.persistence.inheritance.entity.Department;
|
||||||
|
import org.apache.openjpa.persistence.inheritance.entity.Employee;
|
||||||
|
import org.apache.openjpa.persistence.inheritance.entity.FTEmployee;
|
||||||
|
import org.apache.openjpa.persistence.inheritance.entity.PTEmployee;
|
||||||
|
import org.apache.openjpa.persistence.inheritance.entity.Manager;
|
||||||
|
import org.apache.openjpa.persistence.test.SingleEMFTestCase;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Originally reported in the context of entities of a inheritance hierarchy with
|
||||||
|
* JOIN_TABLE strategy.
|
||||||
|
*
|
||||||
|
* <A HREF="http://issues.apache.org/jira/browse/OPENJPA-1536">OPENJPA-1536</A>
|
||||||
|
*
|
||||||
|
* @author Jody Grassel
|
||||||
|
* @author Fay Wang
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public class TestJoinTableStrategy extends SingleEMFTestCase {
|
||||||
|
|
||||||
|
public void setUp() {
|
||||||
|
super.setUp(CLEAR_TABLES, Department.class, Employee.class,
|
||||||
|
PTEmployee.class, FTEmployee.class, Manager.class);
|
||||||
|
|
||||||
|
EntityManager em = emf.createEntityManager();
|
||||||
|
em.getTransaction().begin();
|
||||||
|
Manager m = new Manager();
|
||||||
|
m.setId(1);
|
||||||
|
m.setFirstName("mf1");
|
||||||
|
m.setLastName("ml1");
|
||||||
|
m.setSalary(1000000);
|
||||||
|
m.setVacationDays(20);
|
||||||
|
|
||||||
|
Department d = new Department();
|
||||||
|
d.setId(1);
|
||||||
|
d.setDepartmentName("d1");
|
||||||
|
d.setDepartmentManager(m);
|
||||||
|
m.setDepartment(d);
|
||||||
|
|
||||||
|
Employee e1 = new Employee();
|
||||||
|
e1.setId(2);
|
||||||
|
e1.setFirstName("ef1");
|
||||||
|
e1.setLastName("el1");
|
||||||
|
e1.setDepartment(d);
|
||||||
|
e1.setManager(m);
|
||||||
|
e1.setVacationDays(20);
|
||||||
|
|
||||||
|
em.persist(m);
|
||||||
|
em.persist(d);
|
||||||
|
em.persist(e1);
|
||||||
|
em.getTransaction().commit();
|
||||||
|
em.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void tearDown() {
|
||||||
|
// problem deleting table in MySQL
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testFindEntity() {
|
||||||
|
EntityManager em1 = emf.createEntityManager();
|
||||||
|
Manager m = em1.find(Manager.class, 1);
|
||||||
|
assertNotNull(m);
|
||||||
|
em1.close();
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,91 @@
|
||||||
|
/*
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
* or more contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. The ASF licenses this file
|
||||||
|
* to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance
|
||||||
|
* with the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing,
|
||||||
|
* software distributed under the License is distributed on an
|
||||||
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
* KIND, either express or implied. See the License for the
|
||||||
|
* specific language governing permissions and limitations
|
||||||
|
* under the License.
|
||||||
|
*/
|
||||||
|
package org.apache.openjpa.persistence.inheritance.entity;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import javax.persistence.Entity;
|
||||||
|
import javax.persistence.Id;
|
||||||
|
import javax.persistence.ManyToOne;
|
||||||
|
import javax.persistence.OneToMany;
|
||||||
|
import javax.persistence.Table;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test case and domain classes were originally part of the reported issue
|
||||||
|
* <A href="https://issues.apache.org/jira/browse/OPENJPA-1536">OPENJPA-1536</A>
|
||||||
|
*
|
||||||
|
* @author Jody Grassel
|
||||||
|
* @author Fay Wang
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
@Entity
|
||||||
|
@Table(name="CDepartment")
|
||||||
|
public class Department {
|
||||||
|
@Id
|
||||||
|
private int id;
|
||||||
|
|
||||||
|
private String departmentName;
|
||||||
|
|
||||||
|
@ManyToOne
|
||||||
|
private Manager departmentManager;
|
||||||
|
|
||||||
|
@OneToMany(mappedBy="department")
|
||||||
|
private List<Employee> employeeList;
|
||||||
|
|
||||||
|
public Department() {
|
||||||
|
this.employeeList = new ArrayList<Employee>();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Department(int id, String departmentName) {
|
||||||
|
this.employeeList = new ArrayList<Employee>();
|
||||||
|
this.id = id;
|
||||||
|
this.departmentName = departmentName;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setId(int id) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getDepartmentName() {
|
||||||
|
return departmentName;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setDepartmentName(String departmentName) {
|
||||||
|
this.departmentName = departmentName;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Manager getDepartmentManager() {
|
||||||
|
return departmentManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setDepartmentManager(Manager departmentManager) {
|
||||||
|
this.departmentManager = departmentManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<Employee> getEmployeeList() {
|
||||||
|
return employeeList;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,123 @@
|
||||||
|
/*
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
* or more contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. The ASF licenses this file
|
||||||
|
* to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance
|
||||||
|
* with the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing,
|
||||||
|
* software distributed under the License is distributed on an
|
||||||
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
* KIND, either express or implied. See the License for the
|
||||||
|
* specific language governing permissions and limitations
|
||||||
|
* under the License.
|
||||||
|
*/
|
||||||
|
package org.apache.openjpa.persistence.inheritance.entity;
|
||||||
|
|
||||||
|
import javax.persistence.DiscriminatorColumn;
|
||||||
|
import javax.persistence.DiscriminatorType;
|
||||||
|
import javax.persistence.Entity;
|
||||||
|
import javax.persistence.Id;
|
||||||
|
import javax.persistence.Inheritance;
|
||||||
|
import javax.persistence.InheritanceType;
|
||||||
|
import javax.persistence.ManyToOne;
|
||||||
|
import javax.persistence.Table;
|
||||||
|
import javax.persistence.Version;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test case and domain classes were originally part of the reported issue
|
||||||
|
* <A href="https://issues.apache.org/jira/browse/OPENJPA-1536">OPENJPA-1536</A>
|
||||||
|
*
|
||||||
|
* @author Jody Grassel
|
||||||
|
* @author Fay Wang
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
@Entity
|
||||||
|
@Table(name="CEmployee")
|
||||||
|
@Inheritance(strategy=InheritanceType.JOINED)
|
||||||
|
@DiscriminatorColumn(name="EMP_TYPEL", discriminatorType=DiscriminatorType.INTEGER)
|
||||||
|
public class Employee {
|
||||||
|
|
||||||
|
@Id
|
||||||
|
private int id;
|
||||||
|
|
||||||
|
private String lastName;
|
||||||
|
private String firstName;
|
||||||
|
|
||||||
|
private int vacationDays;
|
||||||
|
|
||||||
|
@ManyToOne
|
||||||
|
private Manager manager;
|
||||||
|
|
||||||
|
@ManyToOne
|
||||||
|
private Department department;
|
||||||
|
|
||||||
|
@Version
|
||||||
|
private long version;
|
||||||
|
|
||||||
|
private transient String str = null;
|
||||||
|
|
||||||
|
public int getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setId(int id) {
|
||||||
|
this.id = id;
|
||||||
|
str = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getLastName() {
|
||||||
|
return lastName;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setLastName(String lastName) {
|
||||||
|
this.lastName = lastName;
|
||||||
|
str = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getFirstName() {
|
||||||
|
return firstName;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setFirstName(String firstName) {
|
||||||
|
this.firstName = firstName;
|
||||||
|
str = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getVacationDays() {
|
||||||
|
return vacationDays;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setVacationDays(int vacationDays) {
|
||||||
|
this.vacationDays = vacationDays;
|
||||||
|
str = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Manager getManager() {
|
||||||
|
return manager;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setManager(Manager manager) {
|
||||||
|
this.manager = manager;
|
||||||
|
str = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Department getDepartment() {
|
||||||
|
return department;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setDepartment(Department department) {
|
||||||
|
this.department = department;
|
||||||
|
str = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public long getVersion() {
|
||||||
|
return version;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,46 @@
|
||||||
|
/*
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
* or more contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. The ASF licenses this file
|
||||||
|
* to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance
|
||||||
|
* with the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing,
|
||||||
|
* software distributed under the License is distributed on an
|
||||||
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
* KIND, either express or implied. See the License for the
|
||||||
|
* specific language governing permissions and limitations
|
||||||
|
* under the License.
|
||||||
|
*/
|
||||||
|
package org.apache.openjpa.persistence.inheritance.entity;
|
||||||
|
|
||||||
|
import javax.persistence.DiscriminatorValue;
|
||||||
|
import javax.persistence.Entity;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test case and domain classes were originally part of the reported issue
|
||||||
|
* <A href="https://issues.apache.org/jira/browse/OPENJPA-1536">OPENJPA-1536</A>
|
||||||
|
*
|
||||||
|
* @author Jody Grassel
|
||||||
|
* @author Fay Wang
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
@Entity
|
||||||
|
@DiscriminatorValue("2")
|
||||||
|
public class FTEmployee extends Employee {
|
||||||
|
private double salary;
|
||||||
|
|
||||||
|
public double getSalary() {
|
||||||
|
return salary;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setSalary(double salary) {
|
||||||
|
this.salary = salary;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,50 @@
|
||||||
|
/*
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
* or more contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. The ASF licenses this file
|
||||||
|
* to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance
|
||||||
|
* with the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing,
|
||||||
|
* software distributed under the License is distributed on an
|
||||||
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
* KIND, either express or implied. See the License for the
|
||||||
|
* specific language governing permissions and limitations
|
||||||
|
* under the License.
|
||||||
|
*/
|
||||||
|
package org.apache.openjpa.persistence.inheritance.entity;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import javax.persistence.DiscriminatorValue;
|
||||||
|
import javax.persistence.Entity;
|
||||||
|
import javax.persistence.OneToMany;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test case and domain classes were originally part of the reported issue
|
||||||
|
* <A href="https://issues.apache.org/jira/browse/OPENJPA-1536">OPENJPA-1536</A>
|
||||||
|
*
|
||||||
|
* @author Jody Grassel
|
||||||
|
* @author Fay Wang
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
@Entity
|
||||||
|
@DiscriminatorValue("3")
|
||||||
|
public class Manager extends FTEmployee {
|
||||||
|
@OneToMany(mappedBy="manager")
|
||||||
|
private List<Employee> managesList;
|
||||||
|
|
||||||
|
public List<Employee> getManagesList() {
|
||||||
|
return managesList;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String toString() {
|
||||||
|
String str = super.toString();
|
||||||
|
return "Manager " + str;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,47 @@
|
||||||
|
/*
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
* or more contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. The ASF licenses this file
|
||||||
|
* to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance
|
||||||
|
* with the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing,
|
||||||
|
* software distributed under the License is distributed on an
|
||||||
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
* KIND, either express or implied. See the License for the
|
||||||
|
* specific language governing permissions and limitations
|
||||||
|
* under the License.
|
||||||
|
*/
|
||||||
|
package org.apache.openjpa.persistence.inheritance.entity;
|
||||||
|
import javax.persistence.*;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test case and domain classes were originally part of the reported issue
|
||||||
|
* <A href="https://issues.apache.org/jira/browse/OPENJPA-1536">OPENJPA-1536</A>
|
||||||
|
*
|
||||||
|
* @author Jody Grassel
|
||||||
|
* @author Fay Wang
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
@Entity
|
||||||
|
@DiscriminatorValue("1")
|
||||||
|
public class PTEmployee extends Employee {
|
||||||
|
private float hourlyWage;
|
||||||
|
|
||||||
|
public PTEmployee() {
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
|
||||||
|
public float getHourlyWage() {
|
||||||
|
return hourlyWage;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setHourlyWage(float hourlyWage) {
|
||||||
|
this.hourlyWage = hourlyWage;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue