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

org.hibernate.annotations.Struct 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 java.lang.annotation.Retention;
import java.lang.annotation.Target;

import org.hibernate.Incubating;

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 the UDT (user defined type) name for the annotated embeddable
 * type or embedded attribute.
 * 

* This annotation may be applied to an embeddable class: *

 * {@code @Embeddable}
 * {@code @Struct(name = "CUST")}
 * public class Customer { ... }
 * 
*

* Alternatively, it may be applied to an embedded attribute: *

 * public class Order {
 *     {@code @Embedded}
 *     {@code @Struct(name = "CUST")}
 *     private Customer customer;
 * }
 * 
* * @since 6.2 */ @Incubating @Target({TYPE, FIELD, METHOD}) @Retention( RUNTIME ) public @interface Struct { /** * The name of the UDT (user defined type). */ String name(); /** * The ordered set of attributes of the UDT, as they appear physically in the DDL. * It is important to specify the attributes in the same order for JDBC interactions to work correctly. * If the annotated type is a record, the order of record components is used as the default order. * If no default order can be inferred, attributes are assumed to be in alphabetical order. */ String[] attributes() default {}; }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy