Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   * Copyright (c) 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014 David Berkman
   * 
   * This file is part of the SmallMind Code Project.
   * 
   * The SmallMind Code Project is free software, you can redistribute
   * it and/or modify it under the terms of GNU Affero General Public
   * License as published by the Free Software Foundation, either version 3
   * of the License, or (at your option) any later version.
  * 
  * The SmallMind Code Project 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. See the GNU
  * General Public License for more details.
  * 
  * You should have received a copy of the the GNU Affero General Public
  * License, along with the SmallMind Code Project. If not, see
  * <http://www.gnu.org/licenses/>.
  * 
  * Additional permission under the GNU Affero GPL version 3 section 7
  * ------------------------------------------------------------------
  * If you modify this Program, or any covered work, by linking or
  * combining it with other code, such other code is not for that reason
  * alone subject to any of the requirements of the GNU Affero GPL
  * version 3.
  */
 package org.smallmind.persistence.orm.hibernate;
 
 import java.util.List;
 
 public abstract class HibernateDao<I extends Serializable & Comparable<I>, D extends Durable<I>> extends ORMDao<I, D, SessionFactorySession> {
 
   public HibernateDao (HibernateProxySession proxySession) {
 
     this(proxySessionnull);
   }
 
   public HibernateDao (HibernateProxySession proxySessionVectoredDao<I, D> vectoredDao) {
 
     super(proxySessionvectoredDao);
   }
 
   public D get (Class<D> durableClass, I id) {
 
     VectoredDao<I, D> vectoredDao;
     D durable;
 
     if ((vectoredDao = getVectoredDao()) == null) {
       if ((durable = acquire(durableClassid)) != null) {
 
         return durable;
       }
     }
     else {
       if ((durable = vectoredDao.get(durableClassid)) != null) {
 
         return durable;
       }
 
       if ((durable = acquire(durableClassid)) != null) {
 
         return vectoredDao.persist(durableClassdurable.);
       }
     }
 
     return null;
   }
 
   @Override
   public D acquire (Class<D> durableClass, I id) {
 
     return durableClass.cast(getSession().getNativeSession().get(durableClassid));
   }
 
   public List<D> list () {
 
   }
 
   public List<D> list (int maxResults) {
    return list(maxResultsmaxResults);
  }
  public List<D> list (int maxResultsint fetchSize) {
  }
  public List<D> list (I greaterThanint maxResults) {
    return list(greaterThanmaxResultsmaxResults);
  }
  public List<D> list (final I greaterThanfinal int maxResultsfinal int fetchSize) {
    return listByCriteria(new CriteriaDetails() {
      @Override
      public Criteria completeCriteria (Criteria criteria) {
        return criteria.add(Restrictions.gt("id"greaterThan)).addOrder(Order.asc("id")).setMaxResults(maxResults).setFetchSize(fetchSize);
      }
    });
  }
  public Iterable<D> scroll () {
  }
  public Iterable<D> scroll (int fetchSize) {
  }
  public Iterable<D> scrollById (final I greaterThanfinal int fetchSize) {
    return scrollByCriteria(new CriteriaDetails() {
      @Override
      public Criteria completeCriteria (Criteria criteria) {
        return criteria.add(Restrictions.gt("id"greaterThan)).addOrder(Order.asc("id")).setFetchSize(fetchSize);
      }
    });
  }
  public long size () {
    return findByCriteria(Long.classnew CriteriaDetails() {
      @Override
      public Criteria completeCriteria (Criteria criteria) {
        return criteria.setProjection(Projections.rowCount());
      }
    });
  }
  public I lastId () {
    return findByCriteria(getIdClass(), new CriteriaDetails() {
      @Override
      public Criteria completeCriteria (Criteria criteria) {
        return criteria.setProjection(Projections.max("id"));
      }
    });
  }
  public D persist (Class<D> durableClass, D durable) {
    D persistentDurable;
    VectoredDao<I, D> vectoredDao = getVectoredDao();
    if (getSession().getNativeSession().contains(durable)) {
      persistentDurable = durable;
    }
    else {
      persistentDurable = getManagedClass().cast(getSession().getNativeSession().merge(durable));
      getSession().flush();
    }
    if (vectoredDao != null) {
      return vectoredDao.persist(durableClasspersistentDurable.);
    }
    return persistentDurable;
  }
  public void delete (Class<D> durableClass, D durable) {
    VectoredDao<I, D> vectoredDao = getVectoredDao();
    if (!getSession().getNativeSession().contains(durable)) {
      getSession().getNativeSession().delete(getSession().getNativeSession().load(durable.getClass(), durable.getId()));
    }
    else {
      getSession().getNativeSession().delete(durable);
    }
    getSession().flush();
    if (vectoredDao != null) {
      vectoredDao.delete(durableClassdurable);
    }
  }
  public D detach (D object) {
    throw new UnsupportedOperationException("Hibernate has no explicit detached state");
  }
  public int executeWithSQLQuery (SQLQueryDetails sqlQueryDetails) {
    return constructSQLQuery(sqlQueryDetails).executeUpdate();
  }
  public D findBySQLQuery (SQLQueryDetails sqlQueryDetails) {
  }
  public <T> T findBySQLQuery (Class<T> returnTypeSQLQueryDetails sqlQueryDetails) {
    SQLQuery sqlQuery;
    sqlQuery = constructSQLQuery(sqlQueryDetails);
    if (Durable.class.isAssignableFrom(returnType)) {
      return returnType.cast(sqlQuery.addEntity(returnType).uniqueResult());
    }
    else if (!SqlType.isKnownType(returnType)) {
      return returnType.cast(sqlQuery.setResultTransformer(Transformers.aliasToBean(returnType)).uniqueResult());
    }
    else {
      Object obj;
      if ((obj = sqlQuery.uniqueResult()) != null) {
        return returnType.cast(obj);
      }
      return null;
    }
  }
  public List<D> listBySQLQuery (SQLQueryDetails sqlQueryDetails) {
    return Collections.checkedList(constructSQLQuery(sqlQueryDetails).addEntity(getManagedClass()).list(), getManagedClass());
  }
  public <T> List<T> listBySQLQuery (Class<T> returnTypeSQLQueryDetails sqlQueryDetails) {
    SQLQuery sqlQuery;
    sqlQuery = constructSQLQuery(sqlQueryDetails);
    if (Durable.class.isAssignableFrom(returnType)) {
      return Collections.checkedList(sqlQuery.addEntity(returnType).list(), returnType);
    }
    else if (!SqlType.isKnownType(returnType)) {
      return Collections.checkedList(sqlQuery.setResultTransformer(Transformers.aliasToBean(returnType)).list(), returnType);
    }
    else {
      LinkedList<T> returnList = new LinkedList<T>();
      for (Object obj : sqlQuery.list()) {
        returnList.add(returnType.cast(obj));
      }
      return returnList;
    }
  }
  public Iterable<D> scrollBySQLQuery (SQLQueryDetails sqlQueryDetails) {
  }
  public int executeWithQuery (QueryDetails queryDetails) {
    return constructQuery(queryDetails).executeUpdate();
  }
  public <T> T findByQuery (Class<T> returnTypeQueryDetails queryDetails) {
    return returnType.cast(constructQuery(queryDetails).uniqueResult());
  }
  public D findByQuery (QueryDetails queryDetails) {
    return getManagedClass().cast(constructQuery(queryDetails).uniqueResult());
  }
  public <T> List<T> listByQuery (Class<T> returnTypeQueryDetails queryDetails) {
    return Collections.checkedList(constructQuery(queryDetails).list(), returnType);
  }
  public List<D> listByQuery (QueryDetails queryDetails) {
    return Collections.checkedList(constructQuery(queryDetails).list(), getManagedClass());
  }
  public <T> Iterable<T> scrollByQuery (Class<T> returnTypeQueryDetails queryDetails) {
    return new ScrollIterator<T>(constructQuery(queryDetails).scroll(.), returnType);
  }
  public Iterable<D> scrollByQuery (QueryDetails queryDetails) {
    return new ScrollIterator<D>(constructQuery(queryDetails).scroll(.), getManagedClass());
  }
  public <T> T findByCriteria (Class<T> returnTypeCriteriaDetails criteriaDetails) {
    return returnType.cast(constructCriteria(criteriaDetails).uniqueResult());
  }
  public D findByCriteria (CriteriaDetails criteriaDetails) {
    return getManagedClass().cast(constructCriteria(criteriaDetails).uniqueResult());
  }
  public <T> List<T> listByCriteria (Class<T> returnTypeCriteriaDetails criteriaDetails) {
    return Collections.checkedList(constructCriteria(criteriaDetails).list(), returnType);
  }
  public List<D> listByCriteria (CriteriaDetails criteriaDetails) {
    return Collections.checkedList(constructCriteria(criteriaDetails).list(), getManagedClass());
  }
  public <T> Iterable<T> scrollByCriteria (Class<T> returnTypeCriteriaDetails criteriaDetails) {
    return new ScrollIterator<T>(constructCriteria(criteriaDetails).scroll(.), returnType);
  }
  public Iterable<D> scrollByCriteria (CriteriaDetails criteriaDetails) {
    return new ScrollIterator<D>(constructCriteria(criteriaDetails).scroll(.), getManagedClass());
  }
  public SQLQuery constructSQLQuery (SQLQueryDetails sqlQueryDetails) {
    return sqlQueryDetails.completeSQLQuery((SQLQuery)getSession().getNativeSession().createSQLQuery(sqlQueryDetails.getSQLQueryString()).setCacheable(true));
  }
  public Query constructQuery (QueryDetails queryDetails) {
    return queryDetails.completeQuery(getSession().getNativeSession().createQuery(queryDetails.getQueryString()).setCacheable(true));
  }
  public Criteria constructCriteria (CriteriaDetails criteriaDetails) {
    Criteria criteria;
    criteria = (criteriaDetails.getAlias() == null) ? getSession().getNativeSession().createCriteria(getManagedClass()) : getSession().getNativeSession().createCriteria(getManagedClass(), criteriaDetails.getAlias());
    return criteriaDetails.completeCriteria(criteria).setCacheable(true);
  }
    return DetachedCriteria.forClass(getManagedClass());
  }
New to GrepCode? Check out our FAQ X