All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.eclipse.persistence.sessions.changesets.ObjectChangeSet Maven / Gradle / Ivy

/*
 * Copyright (c) 1998, 2018 Oracle and/or its affiliates. All rights reserved.
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License v. 2.0 which is available at
 * http://www.eclipse.org/legal/epl-2.0,
 * or the Eclipse Distribution License v. 1.0 which is available at
 * http://www.eclipse.org/org/documents/edl-v10.php.
 *
 * SPDX-License-Identifier: EPL-2.0 OR BSD-3-Clause
 */

// Contributors:
//     Oracle - initial API and implementation from Oracle TopLink
package org.eclipse.persistence.sessions.changesets;

import java.util.List;
import java.util.Vector;
import org.eclipse.persistence.sessions.Session;

/**
 * 

* Purpose: Provides API to the Class that holds all changes made to a particular Object. *

* Description: The ObjectChangeSet class represents a single Object registered in the UnitOfWork. * It is owned by the larger UnitOfWorkChangeSet. */ public interface ObjectChangeSet { boolean equals(Object objectChange); /** * ADVANCED: * This method will return a collection of the names of attributes changed in an object. */ List getChangedAttributeNames(); /** * ADVANCED: * This method returns a reference to the collection of changes within this changeSet. */ List getChanges(); /** * ADVANCE: * This method returns the class type that this changeSet Represents. */ Class getClassType(Session session); /** * ADVANCE: * This method returns the class Name that this changeSet Represents. */ String getClassName(); /** * ADVANCED: * This method returns the key value that this object was stored under in it's respective Map. * This is old relevant for collection mappings that use a Map. */ Object getOldKey(); /** * ADVANCED: * This method returns the key value that this object will be stored under in it's respective Map. * This is old relevant for collection mappings that use a Map. */ Object getNewKey(); /** * ADVANCED: * This method returns the primary key for the object that this change set represents. * @deprecated since EclipseLink 2.1, replaced by getId() * @see #getId() */ @Deprecated Vector getPrimaryKeys(); /** * ADVANCED: * This method returns the primary key for the object that this change set represents. */ Object getId(); /** * ADVANCED: * This method is used to return the parent ChangeSet. */ UnitOfWorkChangeSet getUOWChangeSet(); /** * ADVANCED: * This method is used to return the lock value of the object this changeSet represents. */ Object getWriteLockValue(); /** * ADVANCED: * Returns the change record for the specified attribute name. */ ChangeRecord getChangesForAttributeNamed(String attributeName); /** * ADVANCED: * This method will return true if the specified attribute has been changed. * @param attributeName the name of the attribute to search for. */ boolean hasChangeFor(String attributeName); /** * ADVANCED: * Returns true if this particular changeSet has changes. */ boolean hasChanges(); /** * ADVANCED: * Returns true if this ObjectChangeSet represents a new object. */ boolean isNew(); /** * ADVANCED * Returns true if this ObjectChangeSet should be recalculated after changes in event * @return */ public boolean shouldRecalculateAfterUpdateEvent(); /** * ADVANCED * Set whether this ObjectChangeSet should be recalculated after changes in event */ public void setShouldRecalculateAfterUpdateEvent(boolean shouldRecalculateAfterUpdateEvent); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy