Jump to: navigation, search

Difference between revisions of "EclipseLink/UserGuide/JPA/Advanced JPA Development/Performance/Weaving/Disabling Weaving with Persistence Unit Properties"

(Disabling Weaving with Persistence Unit Properties)
m
 
(2 intermediate revisions by one other user not shown)
Line 1: Line 1:
 +
----
 +
 +
 +
'''[[Image:Elug_draft_icon.png|Warning]] This page is now obsolete. '''
 +
 +
For current information, please see "Weaving" in the ''Java Persistence API (JPA) Extensions Reference for EclipseLink,'':
 +
http://www.eclipse.org/eclipselink/documentation/latest/jpa/extensions/persistenceproperties_ref.htm#CACGCEIJ2
 +
 +
 +
----
 +
 +
 
{{EclipseLink_UserGuide
 
{{EclipseLink_UserGuide
 
|info=y
 
|info=y
Line 20: Line 32:
 
<span id="Example 19-41"></span>
 
<span id="Example 19-41"></span>
 
''''' Disabling Weaving for Change Tracking in the persistence.xml File'''''  
 
''''' Disabling Weaving for Change Tracking in the persistence.xml File'''''  
<div class="pre">
+
<source lang="xml">
<persistence>
+
<persistence>
    <persistence-unit name="HumanResources">
+
  <persistence-unit name="HumanResources">
        <class>com.acme.Employee</class>
+
      <class>com.acme.Employee</class>
+
      ...
        ...
+
      <properties>
        <properties>
+
          <property name="eclipselink.weaving.changetracking" value="false"/>
            <property
+
      </properties>
                name="eclipselink.weaving.changetracking"
+
  </persistence-unit>
                value="false"
+
</persistence>
            />
+
</source>
        </properties>
+
    </persistence-unit>
+
</persistence>
+
</div>
+
  
 
The following example shows how to disable all weaving: in this example, EclipseLink does not weave for lazy loading (indirection), change tracking, or internal optimization.
 
The following example shows how to disable all weaving: in this example, EclipseLink does not weave for lazy loading (indirection), change tracking, or internal optimization.
Line 40: Line 48:
 
<span id="Example 19-42"></span>
 
<span id="Example 19-42"></span>
 
''''' Disabling All Weaving in the persistence.xml File'''''  
 
''''' Disabling All Weaving in the persistence.xml File'''''  
<div class="pre">
+
<source lang="xml">
<persistence>
+
persistence>
    <persistence-unit name="HumanResources">
+
  <persistence-unit name="HumanResources">
        <class>com.acme.Employee</class>
+
      <class>com.acme.Employee</class>
+
      ...
        ...
+
      <properties>
        <properties>
+
          <property name="eclipselink.weaving" value="false"/>
            <property
+
      </properties>
                name="eclipselink.weaving"
+
  </persistence-unit>
                value="false"
+
</persistence>
            />
+
</source>
        </properties>
+
    </persistence-unit>
+
</persistence>
+
</div>
+
  
 
</li>
 
</li>
Line 60: Line 64:
 
</li>
 
</li>
 
</ol>
 
</ol>
 
  
  

Latest revision as of 07:53, 17 April 2013



Warning This page is now obsolete.

For current information, please see "Weaving" in the Java Persistence API (JPA) Extensions Reference for EclipseLink,: http://www.eclipse.org/eclipselink/documentation/latest/jpa/extensions/persistenceproperties_ref.htm#CACGCEIJ2




EclipseLink JPA

link="http://wiki.eclipse.org/EclipseLink"
EclipseLink
Website
Download
Community
Mailing ListForumsIRC
Bugzilla
Open
Help Wanted
Bug Day
Contribute
Browse Source


Disabling Weaving with Persistence Unit Properties

To disable weaving using EclipseLink persistence unit properties:

  1. Configure your persistence.xml file with one or more of the following properties set to true or false:
    • eclipselink.weaving – This can be used to disables all weaving. This defaults to true if weaving is possible in the environment.
    • eclipselink.weaving.lazy – This can be used to disables weaving for lazy loading (indirection). This defaults to true.
    • eclipselink.weaving.changetracking – This can be used to disables weaving for change tracking. This defaults to true if change tracking is possible for the entity (the entity must have LAZY collection relationships, no mutable basic mappings, and no embeddable element collection mappings).
    • eclipselink.weaving.fetchgroups – This can be used to disables weaving for fetch groups. This defaults to true.
    • eclipselink.weaving.internal – This can be used to disables weaving for internal optimization. This defaults to true.
    • eclipselink.weaving.eager – This can be used to enable weaving for indirection on eager relationships, this allows change tracking on eager collection relationships, and improves cache concurrency for eager object relationships. This defaults to false.

    This example shows how to disable weaving for change tracking only.
    Disabling Weaving for Change Tracking in the persistence.xml File
    <persistence>
       <persistence-unit name="HumanResources">
           <class>com.acme.Employee</class>
           ...
           <properties>
               <property name="eclipselink.weaving.changetracking" value="false"/>
           </properties>
       </persistence-unit>
    </persistence>

    The following example shows how to disable all weaving: in this example, EclipseLink does not weave for lazy loading (indirection), change tracking, or internal optimization.

    Disabling All Weaving in the persistence.xml File

    persistence>
       <persistence-unit name="HumanResources">
           <class>com.acme.Employee</class>
           ...
           <properties>
               <property name="eclipselink.weaving" value="false"/>
           </properties>
       </persistence-unit>
    </persistence>
  2. Package and and deploy your application. .


Eclipselink-logo.gif
Version: 2.4 DRAFT
Other versions...