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

org.hibernate.annotations.SQLUpdate Maven / Gradle / Ivy

There is a newer version: 6.6.2.Final
Show newest version
/*
 * Hibernate, Relational Persistence for Idiomatic Java
 *
 * License: GNU Lesser General Public License (LGPL), version 2.1 or later.
 * See the lgpl.txt file in the root directory or .
 */
package org.hibernate.annotations;

import org.hibernate.jdbc.Expectation;

import java.lang.annotation.Repeatable;
import java.lang.annotation.Retention;
import java.lang.annotation.Target;

import static java.lang.annotation.ElementType.FIELD;
import static java.lang.annotation.ElementType.METHOD;
import static java.lang.annotation.ElementType.TYPE;
import static java.lang.annotation.RetentionPolicy.RUNTIME;

/**
 * Specifies a custom SQL DML statement to be used in place of the default SQL
 * generated by Hibernate when an entity or collection row is updated in the
 * database.
 * 

* The given {@linkplain #sql SQL statement} must have exactly the number of JDBC * {@code ?} parameters that Hibernate expects, that is, one for each column * mapped by the entity, in the exact order Hibernate expects. In particular, * the {@linkplain jakarta.persistence.Id primary key} columns come last unless * the entity is {@linkplain jakarta.persistence.Version versioned}, in which case * there must be a second JDBC parameter for the version column, which comes * after the primary key. *

* If a column should not be written as part of the update statement, * and has no corresponding JDBC parameter in the custom SQL, it must be mapped * using {@link jakarta.persistence.Column#updatable() updatable=false}. *

* A custom SQL update statement might assign a value to a mapped column as it * is written. In this case, the corresponding property of the entity remains * unassigned after the update is executed unless * {@link Generated @Generated(event=UPDATE)} is specified, forcing Hibernate * to reread the state of the entity after each update. *

* Similarly, a custom update statement might transform a mapped column value * as it is written. In this case, the state of the entity held in memory * loses synchronization with the database after the update is executed unless * {@link Generated @Generated(event=UPDATE, writable=true)} is specified, again * forcing Hibernate to reread the state of the entity after each update. *

* If an entity has {@linkplain jakarta.persistence.SecondaryTable secondary * tables}, it may have a {@code @SQLUpdate} annotation for each secondary table. * The {@link #table} member must specify the name of the secondary table. * * @author Laszlo Benke */ @Target({TYPE, FIELD, METHOD}) @Retention(RUNTIME) @Repeatable(SQLUpdates.class) public @interface SQLUpdate { /** * Procedure name or SQL {@code UPDATE} statement. */ String sql(); /** * Is the statement callable (aka a {@link java.sql.CallableStatement})? */ boolean callable() default false; /** * An {@link Expectation} class used to verify that the operation was successful. * * @see Expectation.None * @see Expectation.RowCount * @see Expectation.OutParameter */ Class verify() default Expectation.class; /** * A {@link ResultCheckStyle} used to verify that the operation was successful. * * @deprecated use {@link #verify()} with an {@link Expectation} class */ @Deprecated(since = "6.5") ResultCheckStyle check() default ResultCheckStyle.NONE; /** * The name of the table affected by the update statement. Required when the * statement affects a {@linkplain jakarta.persistence.SecondaryTable secondary * table} of an entity. Not required for collections nor when the insert statement * affects the primary table of an entity. * * @return the name of the secondary table * * @since 6.2 */ String table() default ""; }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy