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

org.apache.openjpa.jdbc.meta.ClassStrategy Maven / Gradle / Ivy

There is a newer version: 4.0.1
Show newest version
/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations
 * under the License.
 */
package org.apache.openjpa.jdbc.meta;

import java.sql.SQLException;

import org.apache.openjpa.jdbc.kernel.JDBCFetchConfiguration;
import org.apache.openjpa.jdbc.kernel.JDBCStore;
import org.apache.openjpa.jdbc.sql.Joins;
import org.apache.openjpa.jdbc.sql.Result;
import org.apache.openjpa.jdbc.sql.Select;
import org.apache.openjpa.kernel.OpenJPAStateManager;
import org.apache.openjpa.kernel.PCState;
import org.apache.openjpa.lib.rop.ResultObjectProvider;

/**
 * Mapping from a class to a relational schema.
 *
 * @author Abe White
 * @since 0.4.0
 */
public interface ClassStrategy
    extends Strategy {

    /**
     * Set the class mapping using this strategy. This will be called before
     * use.
     */
    void setClassMapping(ClassMapping owner);

    /**
     * Return true if the this class' primary key columns correspond to the
     * base class' primary key columns used to construct oid values. Base
     * classes always return true. Classes that join to the base class table,
     * though, may not always join using the same columns the base class
     * uses for oid values, or may not use all the columns. When performing a
     * select, we will join down to the most-derived class that is identified
     * by oid values. We cannot use non-primary key field values for joining
     * during selects, because the field values to join on might be the ones
     * we're trying to select! Similarly, we can only reconstruct oid values
     * for selected objects using classes whose primary keys store oid values.
     *
     * @param hasAll if true, there must be a primary key column for every
     * base class primary key column; if false the primary key
     * must only match a subset of the base class primary key columns
     */
    boolean isPrimaryKeyObjectId(boolean hasAll);

    /**
     * Join the mapping and its superclass.
     *
     * @param toThis if false, inner join to the superclass table; if
     * true, outer join from the superclass table to this table
     */
    Joins joinSuperclass(Joins joins, boolean toThis);

    /**
     * Return true if this strategy can perform the given select from
     * the given base mapping.
     * The given state manager may be null if selecting multiple instances.
     */
    boolean supportsEagerSelect(Select sel, OpenJPAStateManager sm,
        JDBCStore store, ClassMapping base, JDBCFetchConfiguration fetch);

    /**
     * Implement this method to customize obtaining a result containing all
     * instances of this class. Return null for standard loading.
     */
    ResultObjectProvider customLoad(JDBCStore store, boolean subclasses,
        JDBCFetchConfiguration fetch, long startIdx, long endIdx)
        throws SQLException;

    /**
     * Implement this method to load the state of a given object, without
     * a previous {@link Result}. Return true if this method handles the
     * load. If the object does not exist in the data store, simply take no
     * action on it (but still return true). Return false to use default
     * loading.
     *
     * @param state if non-null, then you must initialize the state
     * and persistent object of the given state manager
     * (after determining the actual class of the object
     * from the database, if there are possible persistent
     * subclasses); initialization looks like this: 
     * sm.initialize (pcClass, state)
     */
    boolean customLoad(OpenJPAStateManager sm, JDBCStore store,
        PCState state, JDBCFetchConfiguration fetch)
        throws SQLException, ClassNotFoundException;

    /**
     * Implement this method to customize loading from a {@link Result}
     * into an instance. Return true if this mapping handles the
     * load; false if normal loading should proceed after calling this method.
     */
    boolean customLoad(OpenJPAStateManager sm, JDBCStore store,
        JDBCFetchConfiguration fetch, Result result)
        throws SQLException;
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy