com.speedment.runtime.field.DoubleForeignKeyField Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of runtime-deploy Show documentation
Show all versions of runtime-deploy Show documentation
A Speedment bundle that shades all dependencies into one jar. This is
useful when deploying an application on a server.
/**
*
* Copyright (c) 2006-2017, Speedment, Inc. All Rights Reserved.
*
* Licensed 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 com.speedment.runtime.field;
import com.speedment.runtime.config.identifier.ColumnIdentifier;
import com.speedment.runtime.field.internal.DoubleForeignKeyFieldImpl;
import com.speedment.runtime.field.method.DoubleGetter;
import com.speedment.runtime.field.method.DoubleSetter;
import com.speedment.runtime.field.trait.HasFinder;
import com.speedment.runtime.typemapper.TypeMapper;
import javax.annotation.Generated;
/**
* A field that represents a primitive {@code double} value that references
* another column using a foreign key.
*
* @param entity type
* @param database type
* @param foreign entity type
*
* @author Emil Forslund
* @since 3.0.0
*
* @see ReferenceField
* @see ComparableForeignKeyField
*/
@Generated(value = "Speedment")
public interface DoubleForeignKeyField extends DoubleField, HasFinder {
/**
* Creates a new {@link DoubleForeignKeyField} using the default
* implementation.
*
* @param entity type
* @param database type
* @param foreign entity type
* @param identifier column that this field represents
* @param getter method reference to the getter in the entity
* @param setter method reference to the setter in the entity
* @param referenced field in the foreign entity that is referenced
* @param typeMapper type mapper that is applied
* @param unique if represented column only contains unique values
* @return the created field
*/
static DoubleForeignKeyField create(
ColumnIdentifier identifier,
DoubleGetter getter,
DoubleSetter setter,
DoubleField referenced,
TypeMapper typeMapper,
boolean unique) {
return new DoubleForeignKeyFieldImpl<>(
identifier, getter, setter, referenced, typeMapper, unique
);
}
}