0

我正在使用 OpenJPA 2.2.2 我的 persistence.xml 如下

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.1" xmlns="http://xmlns.jcp.org/xml/ns/persistence"    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence http://xmlns.jcp.org/xml/ns/persistence/persistence_2_1.xsd">
<persistence-unit name="PU" transaction-type="RESOURCE_LOCAL">
    <provider>org.apache.openjpa.persistence.PersistenceProviderImpl</provider>

    <class>package.User</class>

    <properties>
        <property name="openjpa.ConnectionURL" value="jdbc:postgresql://localhost:5432/postgres" />
        <property name="openjpa.ConnectionDriverName" value="org.postgresql.Driver" />
        <property name="openjpa.ConnectionUserName" value="postgres" />
        <property name="openjpa.ConnectionPassword" value="****" />

        <property name="openjpa.DynamicEnhancementAgent" value="true" />
        <property name="openjpa.RuntimeUnenhancedClasses" value="supported" />

        <property name="openjpa.Log" value="SQL=TRACE" />
        <property name="openjpa.ConnectionFactoryProperties" value="PrettyPrint=true, PrettyPrintLineLength=72, PrintParameters=true, MaxActive=10, MaxIdle=5, MinIdle=2, MaxWait=60000" />

        <property name="openjpa.jdbc.SynchronizeMappings" value="buildSchema" />
    </properties>
</persistence-unit>

和 User.java

@Entity
@Table(name = "users")
public class User {
    @Id
    @GeneratedValue(strategy = GenerationType.SEQUENCE)
    private long id;
    ...

尽管创建了 seq_table 而没有创建序列(本机)。如何修复它以使用内置序列我正在使用 postgreSQL。另外我不明白为什么在上面使用时每个PK都是前一个PK的+50。

4

1 回答 1

1

另外我不明白为什么在上面使用时每个PK都是前一个PK的+50。

每次PK比上一次+50的原因很可能是因为你经常?创建新的 EntityManagerFactories。每次创建一个新的 EMF 时,它会默认返回序列表获取新的一批 50 个键。每次你扔掉一个 EMF,任何未使用的键基本上都会被扔掉。

于 2013-10-15T16:32:12.390 回答