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

javax.persistence.Query Maven / Gradle / Ivy

There is a newer version: 4.0.66
Show newest version
/*
 * Copyright (c) 1998-2018 Caucho Technology -- all rights reserved
 *
 * This file is part of Resin(R) Open Source
 *
 * Each copy or derived work must preserve the copyright notice and this
 * notice unmodified.
 *
 * Resin Open Source is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * Resin Open Source is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE, or any warranty
 * of NON-INFRINGEMENT.  See the GNU General Public License for more
 * details.
 *
 * You should have received a copy of the GNU General Public License
 * along with Resin Open Source; if not, write to the
 *
 *   Free Software Foundation, Inc.
 *   59 Temple Place, Suite 330
 *   Boston, MA 02111-1307  USA
 *
 * @author Scott Ferguson
 */

package javax.persistence;

import java.util.Calendar;
import java.util.Date;
import java.util.List;
import java.util.Map;
import java.util.Set;

/**
 * The main application interface to the persistence context.
 */
public interface Query {
  /**
   * Executes a SELECT and return the results as a list.
   */
  public List getResultList();

  /**
   * Returns the single result of a query.
   */
  public Object getSingleResult();

  /**
   * An update or delete query.
   */
  public int executeUpdate();

  /**
   * The maximum number of results to retrieve.
   */
  public Query setMaxResults(int maxResult);

  /**
   * The maximum number of results to retrieve.
   *
   * @Since JPA 2.0
   */
  public int getMaxResults();

  /**
   * Sets the first result.
   */
  public Query setFirstResult(int startPosition);

  /**
   * The first to retrieve.
   *
   * @Since JPA 2.0
   */
  public int getFirstResult();

  /**
   * An implementation-specific hint.
   */
  public Query setHint(String hintName, Object value);

  /**
   * Returns the implementation-specific hints
   *
   * @Since JPA 2.0
   */
  public Map getHints();

  /**
   * Binds a named parameter.
   */
  public  Query setParameter(Parameter param, T value);

  /**
   * Sets a calendar parameter.
   */
  public Query setParameter(Parameter param,
                            Calendar date, 
                            TemporalType type); 

  /**
   * Sets a date parameter.
   */
  public Query setParameter(Parameter param,
                            java.util.Date value,
                            TemporalType temporalType);

  /**
   * Binds a position parameter.
   */
  public Query setParameter(String name, Object value);

  /**
   * Binds a position parameter.
   */
  public Query setParameter(int pos, Object value);

  /**
   * Sets a calendar parameter.
   */
  public Query setParameter(String name,
                            Calendar date, 
                            TemporalType type); 

  /**
   * Sets a date parameter.
   */
  public Query setParameter(String name,
                            java.util.Date date,
                            TemporalType type); 

  /**
   * Sets a date parameter.
   */
  public Query setParameter(int pos, Date date, TemporalType type); 

  /**
   * Sets a calendar parameter.
   */
  public Query setParameter(int pos, Calendar date, TemporalType type);
  
  public Set> getParameters();
  
  public Parameter getParameter(String name);
  
  public  Parameter getParameter(String name, Class type);
  
  public Parameter getParameter(int pos);
  
  public  Parameter getParameter(int position, Class type);

  public boolean isBound(Parameter param);
  
  public  T getParameterValue(Parameter param);
  
  public Object getParameterValue(String name);
  
  public Object getParameterValue(int position);
  
  /**
   * Sets the flush type.
   */
  public Query setFlushMode(FlushModeType flushMode);

  /**
   * Gets the flush type.
   *
   * @since JPA 2.0
   */
  public FlushModeType getFlushMode();

  /**
   * Sets the lock type.
   *
   * @since JPA 2.0
   */
  public Query setLockMode(LockModeType lockMode);

  /**
   * Gets the lock type.
   *
   * @since JPA 2.0
   */
  public LockModeType getLockMode();
  
  public  T unwrap(Class cl);
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy