0

私のpersistence.xmlは次を使用するためdrop-and-create-tables

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
  <persistence-unit name="USENETPU" transaction-type="RESOURCE_LOCAL">
    <provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
    <class>net.bounceme.dur.usenet.model.NewsgroupsArticles</class>
    <class>net.bounceme.dur.usenet.model.Article</class>
    <class>net.bounceme.dur.usenet.model.Newsgroup</class>
    <properties>
      <property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/nntp"/>
      <property name="javax.persistence.jdbc.password" value="password"/>
      <property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver"/>
      <property name="javax.persistence.jdbc.user" value="java"/>
      <property name="toplink.ddl-generation" value="drop-and-create-tables"/>
      <property name="eclipselink.ddl-generation" value="drop-and-create-tables"/>
    </properties>
  </persistence-unit>
</persistence>

トリガーは実行ごとに削除されます。トリガーが削除されないようにするには、どこにトリガーを配置できますか?

4

1 に答える 1

1

を使用する必要がありますSessionCustomizer。また、永続化プロパティ内に、実装を指すプロパティを挿入する必要がありますSessionCustomizer

properties.put(PersistenceUnitProperties.SESSION_CUSTOMIZER, MySessionCustomizer.class.getName());

また

<property name="eclipselink.session.customizer" value="foo.bar.MySessionCustomizer" />

このセッション カスタマイザー内で、トリガー コードを読み込んで、次のように実行できます。

unitOfWork.executeNonSelectingSQL(sql);

このトピックに関する詳細な説明は、ここにあります

于 2012-07-29T11:00:27.353 に答える