EclipseLink中具有动态实体的序列

时间:2011-04-08 17:35:55

标签: java dynamic eclipselink sequence entities

我试图让动态实体的序列在EclipseLink中工作,我需要一些帮助。

我定义了我的动态实体,如下所示:

    EntityManagerFactory emf = Persistence.createEntityManagerFactory("default");
    EntityManager em = emf.createEntityManager();

    Session session = JpaHelper.getEntityManager(em).getServerSession();
    DynamicClassLoader dcl = DynamicClassLoader.lookup(session);

    Class<?> testClass = dcl.createDynamicClass("org.persistence.Test");

    JPADynamicTypeBuilder test = new JPADynamicTypeBuilder(testClass, null, "TEST");

    test.addDirectMapping("id", long.class, "T_ID");
    test.setPrimaryKeyFields("T_ID");
    test.addDirectMapping("col1", long.class, "T_COL1");
    test.addDirectMapping("col2", int.class, "T_COL2");
    test.addDirectMapping("col3", String.class, "T_COL3");
    test.addDirectMapping("col4", String.class, "T_COL4");
    test.addDirectMapping("col5", double.class, "T_COL5");
    test.addDirectMapping("col6", double.class, "T_COL6");

    DynamicHelper helper = new JPADynamicHelper(em);
    helper.addTypes(true, true, test.getType());

我注意到一切都是根据指​​定创建的。我试图寻找一些文档如何使用数据库序列,我注意到了JPADynamicTypeBuilder.configureSequencing(Sequence,String,String)方法。但我找不到任何关于如何做的例子。我玩弄了这种方法,我总是使用默认的排序策略,即一个名为SEQUENCE的表。

我尝试使用@GeneratedValue和@SequenceGenerator预编译实体,一切正常,所以我对动态实体做错了。

有谁知道我可能做错了什么?

这似乎无关紧要,但无论如何,我告诉我的数据库是Oracle。

提前致谢,

2 个答案:

答案 0 :(得分:1)

我没有关于Sequence对象的详细信息,所以我的示例只是通用的,但以下内容应该有效:

test.configureSequencing(
      new NativeSequence("ORACLE_SEQ_OBJ", 1, 1),
      "ORACLE_SEQ_OBJ",
      "T_ID");

答案 1 :(得分:0)

您可以在JPADynamicTypeBuilder上使用configureSequencing方法来设置序列。

以下是一个很好的例子:http://dev.eclipse.org/svnroot/rt/org.eclipse.persistence/branches/2.1/trunk/examples/jpa.employee/eclipselink.example.jpa.employee.dynamic/src/example/EmployeeDynamicMappings.java

我仍在尝试使用表序列,但它给了我一个错误:

Exception [EclipseLink-41] (Eclipse Persistence Services - 2.4.0.v20120608-r11652): org.eclipse.persistence.exceptions.DescriptorException
Exception Description: A non-read-only mapping must be defined for the sequence number field.