Author: allee8285
Date: Mon Oct 1 22:15:42 2012
New Revision: 1392661
URL: http://svn.apache.org/viewvc?rev=1392661&view=rev
Log:
OPENJPA-2247 Complete fix for 1x1 bi and mx1 uni relationships of the described
problem.
Added:
openjpa/trunk/openjpa-persistence-jdbc/src/test/java/org/apache/openjpa/meta/PChildBi.java
(with props)
Modified:
openjpa/trunk/openjpa-jdbc/src/main/java/org/apache/openjpa/jdbc/meta/MappingRepository.java
openjpa/trunk/openjpa-persistence-jdbc/src/test/java/org/apache/openjpa/meta/Parent.java
openjpa/trunk/openjpa-persistence-jdbc/src/test/java/org/apache/openjpa/meta/TestSecondaryTable.java
Modified:
openjpa/trunk/openjpa-jdbc/src/main/java/org/apache/openjpa/jdbc/meta/MappingRepository.java
URL:
http://svn.apache.org/viewvc/openjpa/trunk/openjpa-jdbc/src/main/java/org/apache/openjpa/jdbc/meta/MappingRepository.java?rev=1392661&r1=1392660&r2=1392661&view=diff
==============================================================================
---
openjpa/trunk/openjpa-jdbc/src/main/java/org/apache/openjpa/jdbc/meta/MappingRepository.java
(original)
+++
openjpa/trunk/openjpa-jdbc/src/main/java/org/apache/openjpa/jdbc/meta/MappingRepository.java
Mon Oct 1 22:15:42 2012
@@ -88,7 +88,6 @@ import org.apache.openjpa.jdbc.sql.JoinS
import org.apache.openjpa.lib.conf.Configurable;
import org.apache.openjpa.lib.conf.Configurations;
import org.apache.openjpa.lib.util.J2DoPrivHelper;
-import org.apache.openjpa.lib.util.JavaVersions;
import org.apache.openjpa.lib.util.Localizer;
import org.apache.openjpa.meta.ClassMetaData;
import org.apache.openjpa.meta.FieldMetaData;
@@ -1084,7 +1083,10 @@ public class MappingRepository extends M
field.getAssociationType() == FieldMetaData.MANY_TO_ONE &&
hasJoinTable(field) &&
!isBidirectional(field)) {
-
field.getValueMapping().getValueInfo().setColumns(field.getElementMapping().getValueInfo().getColumns());
+ List<Column> cols =
field.getElementMapping().getValueInfo().getColumns();
+ if (cols != null && cols.size() > 0) {
+ field.getValueMapping().getValueInfo().setColumns(cols);
+ }
return true;
}
return false;
@@ -1096,8 +1098,9 @@ public class MappingRepository extends M
hasJoinTable(field) &&
!isBidirectional(field)) {
List<Column> cols =
field.getElementMapping().getValueInfo().getColumns();
- if (cols != null && cols.size() > 0)
+ if (cols != null && cols.size() > 0) {
field.getValueMapping().getValueInfo().setColumns(cols);
+ }
return true;
}
return false;
@@ -1108,7 +1111,10 @@ public class MappingRepository extends M
field.getAssociationType() == FieldMetaData.ONE_TO_ONE &&
hasJoinTable(field) &&
isBidirectional(field)) {
-
field.getValueMapping().getValueInfo().setColumns(field.getElementMapping().getValueInfo().getColumns());
+ List<Column> cols =
field.getElementMapping().getValueInfo().getColumns();
+ if (cols != null && cols.size() > 0) {
+ field.getValueMapping().getValueInfo().setColumns(cols);
+ }
return true;
}
return false;
Added:
openjpa/trunk/openjpa-persistence-jdbc/src/test/java/org/apache/openjpa/meta/PChildBi.java
URL:
http://svn.apache.org/viewvc/openjpa/trunk/openjpa-persistence-jdbc/src/test/java/org/apache/openjpa/meta/PChildBi.java?rev=1392661&view=auto
==============================================================================
---
openjpa/trunk/openjpa-persistence-jdbc/src/test/java/org/apache/openjpa/meta/PChildBi.java
(added)
+++
openjpa/trunk/openjpa-persistence-jdbc/src/test/java/org/apache/openjpa/meta/PChildBi.java
Mon Oct 1 22:15:42 2012
@@ -0,0 +1,42 @@
+/*
+ * 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.meta;
+
+import javax.persistence.Basic;
+import javax.persistence.Entity;
+import javax.persistence.GeneratedValue;
+import javax.persistence.Id;
+import javax.persistence.OneToOne;
+import javax.persistence.Version;
+
+@Entity
+public class PChildBi {
+ @Id
+ @GeneratedValue
+ int idChild;
+
+ @Version
+ int version;
+
+ @Basic
+ String basic;
+
+ @OneToOne
+ Parent parent;
+}
Propchange:
openjpa/trunk/openjpa-persistence-jdbc/src/test/java/org/apache/openjpa/meta/PChildBi.java
------------------------------------------------------------------------------
svn:eol-style = native
Modified:
openjpa/trunk/openjpa-persistence-jdbc/src/test/java/org/apache/openjpa/meta/Parent.java
URL:
http://svn.apache.org/viewvc/openjpa/trunk/openjpa-persistence-jdbc/src/test/java/org/apache/openjpa/meta/Parent.java?rev=1392661&r1=1392660&r2=1392661&view=diff
==============================================================================
---
openjpa/trunk/openjpa-persistence-jdbc/src/test/java/org/apache/openjpa/meta/Parent.java
(original)
+++
openjpa/trunk/openjpa-persistence-jdbc/src/test/java/org/apache/openjpa/meta/Parent.java
Mon Oct 1 22:15:42 2012
@@ -22,6 +22,7 @@ import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
+import javax.persistence.ManyToOne;
import javax.persistence.OneToOne;
import javax.persistence.PrimaryKeyJoinColumn;
import javax.persistence.SecondaryTable;
@@ -41,4 +42,11 @@ public class Parent {
@JoinColumn(name = "CHILD_REF", table = "ParentSecondaryTable",
referencedColumnName = "idChild")
PChild child;
+ @OneToOne
+ @JoinColumn(name = "CHILDBI_REF", table = "ParentSecondaryTable",
referencedColumnName = "idChild")
+ PChildBi childbi;
+
+ @ManyToOne
+ @JoinColumn(name = "CHILDREN_REF", table = "ParentSecondaryTable",
referencedColumnName = "idChild")
+ PChild children;
}
Modified:
openjpa/trunk/openjpa-persistence-jdbc/src/test/java/org/apache/openjpa/meta/TestSecondaryTable.java
URL:
http://svn.apache.org/viewvc/openjpa/trunk/openjpa-persistence-jdbc/src/test/java/org/apache/openjpa/meta/TestSecondaryTable.java?rev=1392661&r1=1392660&r2=1392661&view=diff
==============================================================================
---
openjpa/trunk/openjpa-persistence-jdbc/src/test/java/org/apache/openjpa/meta/TestSecondaryTable.java
(original)
+++
openjpa/trunk/openjpa-persistence-jdbc/src/test/java/org/apache/openjpa/meta/TestSecondaryTable.java
Mon Oct 1 22:15:42 2012
@@ -23,7 +23,7 @@ import org.apache.openjpa.persistence.te
public class TestSecondaryTable extends SingleEMFTestCase {
public void setUp() {
- setUp(Parent.class, PChild.class
+ setUp(Parent.class, PChild.class, PChildBi.class
// Hard code to 2.0 p.xml value. If the p.xml is 1.0, this value will
be changed to false, and the test
// won't fail.
, "openjpa.Compatibility", "NonDefaultMappingAllowed=true");
@@ -36,6 +36,13 @@ public class TestSecondaryTable extends
FieldMapping fm = getMapping(Parent.class).getFieldMapping("child");
assertNotNull(fm);
assertEquals("CHILD_REF",
fm.getColumns()[0].getIdentifier().getName());
- }
+ fm = getMapping(Parent.class).getFieldMapping("childbi");
+ assertNotNull(fm);
+ assertEquals("CHILDBI_REF",
fm.getColumns()[0].getIdentifier().getName());
+
+ fm = getMapping(Parent.class).getFieldMapping("children");
+ assertNotNull(fm);
+ assertEquals("CHILDREN_REF",
fm.getColumns()[0].getIdentifier().getName());
+ }
}