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

javax.persistence.NamedNativeQuery Maven / Gradle / Ivy

There is a newer version: 3.0
Show newest version
/*
 * Copyright (c) 2008, 2009, 2011 Oracle, Inc. All rights reserved.
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0
 * which accompanies this distribution.  The Eclipse Public License is available
 * at http://www.eclipse.org/legal/epl-v10.html and the Eclipse Distribution License
 * is available at http://www.eclipse.org/org/documents/edl-v10.php.
 */
package javax.persistence;

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

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

/**
 * Specifies a named native SQL query. Query names are scoped to the persistence unit. The
 * NamedNativeQuery annotation can be applied to an entity or mapped superclass.
 *
 * @since Java Persistence 1.0
 */
@Target({TYPE})
@Retention(RUNTIME)
@Repeatable(NamedNativeQueries.class)
public @interface NamedNativeQuery {
  /**
   * The name used to refer to the query with the {@link EntityManager} methods that create query objects.
   *
   * @return The name
   */
  String name();

  /**
   * The SQL query string.
   *
   * @return The SQL string
   */
  String query();

  /**
   * Query properties and hints. (May include vendor-specific query hints.)
   *
   * @return any hints
   */
  QueryHint[] hints() default {};

  /**
   * The class of the result.
   *
   * @return The result class
   */
  Class resultClass() default void.class;

  /**
   * The name of a {@link SqlResultSetMapping}, as defined in metadata.
   *
   * @return ResultSet mapping
   */
  String resultSetMapping() default "";
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy