Hi,
I have I inheritance-problem. I want to map two classes to one table. They are defined as followed:
class A {
int id;
protected String ojbConcreteClass;
// some attributes
}class B extends A {
// some additional attributes
}
I created class-descriptors for each of the table:
<class-descriptor class="A" table="table">
// field-descriptors for A inluding ojbConcreteClass
</class>and
<class-descriptor class="B" table="table" extends="A"> // additional field-descriptors for B </class>
So: When I try to store an instance of Type A everything is fine. But when I try to store an instance of Type B OJB complains:
Caused by: org.apache.ojb.broker.metadata.ClassNotPersistenceCapableException: OJB needs at least one primary key attribute for class objectsRealClass=class kos.wnetz.om.RelationHistoryEvent, objectTopLevelClass=class kos.wnetz.om.RelationHistoryEvent
at org.apache.ojb.broker.Identity.checkForPrimaryKeys(Identity.java:245)
at org.apache.ojb.broker.Identity.init(Identity.java:121)
So I also tried to include the field-descriptors of the superclass in the class-descriptor for class B. But then I get an even worse error:
Caused by: java.sql.SQLException: Parameter index out of range (8 > 7).
at com.mysql.jdbc.PreparedStatement.setInternal(PreparedStatement.java:1940)
at com.mysql.jdbc.PreparedStatement.setString(PreparedStatement.java:1075)
at com.mysql.jdbc.PreparedStatement.setObject(PreparedStatement.java:766)
at com.mysql.jdbc.PreparedStatement.setObject(PreparedStatement.java:892)
at org.apache.ojb.broker.platforms.PlatformDefaultImpl.setObjectForStatement(PlatformDefaultImpl.java:227)
at org.apache.ojb.broker.platforms.PlatformMySQLImpl.setObjectForStatement(PlatformMySQLImpl.java:87)
at org.apache.ojb.broker.accesslayer.StatementManager.bindInsert(StatementManager.java:449)
at org.apache.ojb.broker.accesslayer.JdbcAccessImpl.executeInsert(JdbcAccessImpl.java:193)
... 47 more
So obviously I am missing somthing. do you have any suggestions?
Tino
--------------------------------------------------------------------- To unsubscribe, e-mail: [EMAIL PROTECTED] For additional commands, e-mail: [EMAIL PROTECTED]
