Java tutorial
// license-header java merge-point // // Attention: Generated code! Do not modify by hand! // Generated by: hibernate/SpringHibernateDaoBase.vsl in andromda-spring-cartridge. // package com.algoTrader.entity; import com.algoTrader.PrincipalStore; import com.algoTrader.PropertySearch; import com.algoTrader.Search; import com.algoTrader.enumeration.Currency; import com.algoTrader.enumeration.TransactionType; import java.math.BigDecimal; import java.security.Principal; import java.util.Collection; import java.util.Date; import java.util.LinkedHashSet; import java.util.List; import java.util.Set; import org.andromda.spring.PaginationResult; import org.apache.commons.collections.CollectionUtils; import org.apache.commons.collections.Transformer; import org.hibernate.Criteria; import org.hibernate.HibernateException; import org.hibernate.Query; import org.hibernate.ScrollableResults; import org.hibernate.Session; import org.springframework.orm.hibernate3.HibernateCallback; import org.springframework.orm.hibernate3.support.HibernateDaoSupport; /** * <p> * Base Spring DAO Class: is able to create, update, remove, load, and find * objects of type <code>Transaction</code>. * </p> * * @see Transaction */ public abstract class TransactionDaoBase extends HibernateDaoSupport implements TransactionDao { /** * {@inheritDoc} */ @Override public Object get(final int transform, final int id) { final Object entity = this.getHibernateTemplate().get(TransactionImpl.class, new Integer(id)); return transformEntity(transform, (Transaction) entity); } /** * {@inheritDoc} */ @Override public Transaction get(int id) { return (Transaction) this.get(TRANSFORM_NONE, id); } /** * {@inheritDoc} */ @Override public Object load(final int transform, final int id) { final Object entity = this.getHibernateTemplate().get(TransactionImpl.class, new Integer(id)); return transformEntity(transform, (Transaction) entity); } /** * {@inheritDoc} */ @Override public Transaction load(int id) { return (Transaction) this.load(TRANSFORM_NONE, id); } /** * {@inheritDoc} */ @Override @SuppressWarnings({ "unchecked" }) public Collection<Transaction> loadAll() { return (Collection<Transaction>) this.loadAll(TransactionDao.TRANSFORM_NONE); } /** * {@inheritDoc} */ @Override public Collection<?> loadAll(final int transform) { return this.loadAll(transform, -1, -1); } /** * {@inheritDoc} */ @Override public Collection<?> loadAll(final int pageNumber, final int pageSize) { return this.loadAll(TransactionDao.TRANSFORM_NONE, pageNumber, pageSize); } /** * {@inheritDoc} */ @Override public Collection<?> loadAll(final int transform, final int pageNumber, final int pageSize) { try { final Criteria criteria = this.getSession(false).createCriteria(TransactionImpl.class); if (pageNumber > 0 && pageSize > 0) { criteria.setFirstResult(this.calculateFirstResult(pageNumber, pageSize)); criteria.setMaxResults(pageSize); } final Collection<?> results = criteria.list(); this.transformEntities(transform, results); return results; } catch (HibernateException ex) { throw super.convertHibernateAccessException(ex); } } /** * firstResult = (pageNumber - 1) * pageSize * @param pageNumber * @param pageSize * @return firstResult */ protected int calculateFirstResult(int pageNumber, int pageSize) { int firstResult = 0; if (pageNumber > 0) { firstResult = (pageNumber - 1) * pageSize; } return firstResult; } /** * {@inheritDoc} */ @Override public Transaction create(Transaction transaction) { return (Transaction) this.create(TransactionDao.TRANSFORM_NONE, transaction); } /** * {@inheritDoc} */ @Override public Object create(final int transform, final Transaction transaction) { if (transaction == null) { throw new IllegalArgumentException("Transaction.create - 'transaction' can not be null"); } this.getHibernateTemplate().save(transaction); return this.transformEntity(transform, transaction); } /** * {@inheritDoc} */ @Override @SuppressWarnings({ "unchecked" }) public Collection<Transaction> create(final Collection<Transaction> entities) { return (Collection<Transaction>) create(TransactionDao.TRANSFORM_NONE, entities); } /** * {@inheritDoc} */ @Override public Collection<?> create(final int transform, final Collection<Transaction> entities) { if (entities == null) { throw new IllegalArgumentException("Transaction.create - 'entities' can not be null"); } this.getHibernateTemplate().executeWithNativeSession(new HibernateCallback() { public Object doInHibernate(Session session) throws HibernateException { for (Transaction entity : entities) { create(transform, entity); } return null; } }); return entities; } /** * {@inheritDoc} */ @Override public Transaction create(Date dateTime, long quantity, BigDecimal price, BigDecimal commission, Currency currency, TransactionType type) { return (Transaction) this.create(TransactionDao.TRANSFORM_NONE, dateTime, quantity, price, commission, currency, type); } /** * {@inheritDoc} */ @Override public Object create(final int transform, Date dateTime, long quantity, BigDecimal price, BigDecimal commission, Currency currency, TransactionType type) { Transaction entity = new TransactionImpl(); entity.setDateTime(dateTime); entity.setQuantity(quantity); entity.setPrice(price); entity.setCommission(commission); entity.setCurrency(currency); entity.setType(type); return this.create(transform, entity); } /** * {@inheritDoc} */ @Override public void update(Transaction transaction) { if (transaction == null) { throw new IllegalArgumentException("Transaction.update - 'transaction' can not be null"); } this.getHibernateTemplate().update(transaction); } /** * {@inheritDoc} */ @Override public void update(final Collection<Transaction> entities) { if (entities == null) { throw new IllegalArgumentException("Transaction.update - 'entities' can not be null"); } this.getHibernateTemplate().executeWithNativeSession(new HibernateCallback() { public Object doInHibernate(Session session) throws HibernateException { for (Transaction entity : entities) { update(entity); } return null; } }); } /** * {@inheritDoc} */ @Override public void remove(Transaction transaction) { if (transaction == null) { throw new IllegalArgumentException("Transaction.remove - 'transaction' can not be null"); } this.getHibernateTemplate().delete(transaction); } /** * {@inheritDoc} */ @Override public void remove(int id) { Transaction entity = this.get(id); if (entity != null) { this.remove(entity); } } /** * {@inheritDoc} */ @Override public void remove(Collection<Transaction> entities) { if (entities == null) { throw new IllegalArgumentException("Transaction.remove - 'entities' can not be null"); } this.getHibernateTemplate().deleteAll(entities); } /** * {@inheritDoc} */ @Override @SuppressWarnings({ "unchecked" }) public List<Transaction> findAllTrades() { return (List<Transaction>) this.findAllTrades(TransactionDao.TRANSFORM_NONE); } /** * {@inheritDoc} */ @Override public List<?> findAllTrades(final int transform) { return this.findAllTrades(transform, -1, -1); } /** * {@inheritDoc} */ @Override @SuppressWarnings({ "unchecked" }) public List<Transaction> findAllTrades(final String queryString) { return (List<Transaction>) this.findAllTrades(TransactionDao.TRANSFORM_NONE, queryString); } /** * {@inheritDoc} */ @Override @SuppressWarnings({ "unchecked" }) public List<Transaction> findAllTrades(final int pageNumber, final int pageSize) { return (List<Transaction>) this.findAllTrades(TransactionDao.TRANSFORM_NONE, pageNumber, pageSize); } /** * {@inheritDoc} */ @Override @SuppressWarnings({ "unchecked" }) public List<Transaction> findAllTrades(final String queryString, final int pageNumber, final int pageSize) { return (List<Transaction>) this.findAllTrades(TransactionDao.TRANSFORM_NONE, queryString, pageNumber, pageSize); } /** * {@inheritDoc} */ @Override public List<?> findAllTrades(final int transform, final String queryString) { return this.findAllTrades(transform, queryString, -1, -1); } /** * {@inheritDoc} */ @Override public List<?> findAllTrades(final int transform, final int pageNumber, final int pageSize) { return this.findAllTrades(transform, "from TransactionImpl as t join fetch t.security where t.type = 'BUY' or t.type = 'SELL' or t.type = 'EXPIRATION' order by t.id", pageNumber, pageSize); } /** * {@inheritDoc} */ @Override @SuppressWarnings("unchecked") public List<?> findAllTrades(final int transform, final String queryString, int pageNumber, int pageSize) { try { Query queryObject = super.getSession(false).createQuery(queryString); queryObject.setCacheable(true); if (pageNumber > 0 && pageSize > 0) { queryObject.setFirstResult(this.calculateFirstResult(pageNumber, pageSize)); queryObject.setMaxResults(pageSize); } List results = queryObject.list(); transformEntities(transform, results); return results; } catch (HibernateException ex) { throw super.convertHibernateAccessException(ex); } } /** * {@inheritDoc} */ @Override @SuppressWarnings({ "unchecked" }) public List<Transaction> findAllCashflows() { return (List<Transaction>) this.findAllCashflows(TransactionDao.TRANSFORM_NONE); } /** * {@inheritDoc} */ @Override public List<?> findAllCashflows(final int transform) { return this.findAllCashflows(transform, -1, -1); } /** * {@inheritDoc} */ @Override @SuppressWarnings({ "unchecked" }) public List<Transaction> findAllCashflows(final String queryString) { return (List<Transaction>) this.findAllCashflows(TransactionDao.TRANSFORM_NONE, queryString); } /** * {@inheritDoc} */ @Override @SuppressWarnings({ "unchecked" }) public List<Transaction> findAllCashflows(final int pageNumber, final int pageSize) { return (List<Transaction>) this.findAllCashflows(TransactionDao.TRANSFORM_NONE, pageNumber, pageSize); } /** * {@inheritDoc} */ @Override @SuppressWarnings({ "unchecked" }) public List<Transaction> findAllCashflows(final String queryString, final int pageNumber, final int pageSize) { return (List<Transaction>) this.findAllCashflows(TransactionDao.TRANSFORM_NONE, queryString, pageNumber, pageSize); } /** * {@inheritDoc} */ @Override public List<?> findAllCashflows(final int transform, final String queryString) { return this.findAllCashflows(transform, queryString, -1, -1); } /** * {@inheritDoc} */ @Override public List<?> findAllCashflows(final int transform, final int pageNumber, final int pageSize) { return this.findAllCashflows(transform, "from TransactionImpl as t where t.type = 'CREDIT' or t.type = 'DEBIT' or t.type = 'INTREST' or t.type = 'FEES' order by t.id", pageNumber, pageSize); } /** * {@inheritDoc} */ @Override @SuppressWarnings("unchecked") public List<?> findAllCashflows(final int transform, final String queryString, int pageNumber, int pageSize) { try { Query queryObject = super.getSession(false).createQuery(queryString); queryObject.setCacheable(true); if (pageNumber > 0 && pageSize > 0) { queryObject.setFirstResult(this.calculateFirstResult(pageNumber, pageSize)); queryObject.setMaxResults(pageSize); } List results = queryObject.list(); transformEntities(transform, results); return results; } catch (HibernateException ex) { throw super.convertHibernateAccessException(ex); } } /** * Allows transformation of entities into value objects * (or something else for that matter), when the <code>transform</code> * flag is set to one of the constants defined in <code>TransactionDao</code>, please note * that the {@link #TRANSFORM_NONE} constant denotes no transformation, so the entity itself * will be returned. * * If the integer argument value is unknown {@link #TRANSFORM_NONE} is assumed. * * @param transform one of the constants declared in {@link TransactionDao} * @param entity an entity that was found * @return the transformed entity (i.e. new value object, etc) * @see TransactionDao#transformEntity(int, Transaction) */ public Object transformEntity(final int transform, final Transaction entity) { Object target = null; if (entity != null) { switch (transform) { case TransactionDao.TRANSFORM_NONE: // fall-through default: target = entity; } } return target; } /** * {@inheritDoc} */ @Override public void transformEntities(final int transform, final Collection<?> entities) { switch (transform) { case TransactionDao.TRANSFORM_NONE: // fall-through default: // do nothing; } } /** * @see TransactionDao#toEntities(Collection) */ public void toEntities(final Collection<?> results) { if (results != null) { CollectionUtils.transform(results, this.ENTITYTRANSFORMER); } } /** * This anonymous transformer is designed to transform report query results * (which result in an array of entities) to {@link Transaction} * using the Jakarta Commons-Collections Transformation API. */ private Transformer ENTITYTRANSFORMER = new Transformer() { public Object transform(Object input) { Object result = null; if (input instanceof Object[]) { result = toEntity((Object[]) input); } else if (input instanceof Transaction) { result = input; } return result; } }; /** * @param row * @return Transaction */ protected Transaction toEntity(Object[] row) { Transaction target = null; if (row != null) { final int numberOfObjects = row.length; for (int ctr = 0; ctr < numberOfObjects; ctr++) { final Object object = row[ctr]; if (object instanceof Transaction) { target = (Transaction) object; break; } } } return target; } /** * Gets the current <code>principal</code> if one has been set, * otherwise returns <code>null</code>. * * @return the current principal */ protected Principal getPrincipal() { return PrincipalStore.get(); } /** * {@inheritDoc} */ @Override @SuppressWarnings({ "unchecked" }) public PaginationResult search(final int transform, final int pageNumber, final int pageSize, final Search search) { try { search.setPageNumber(pageNumber); search.setPageSize(pageSize); final PropertySearch propertySearch = new PropertySearch(this.getSession(false), TransactionImpl.class, search); final List results = propertySearch.executeAsList(); this.transformEntities(transform, results); return new PaginationResult(results.toArray(new Object[results.size()]), propertySearch.getTotalCount()); } catch (HibernateException ex) { throw super.convertHibernateAccessException(ex); } } /** * {@inheritDoc} */ @Override public PaginationResult search(final int pageNumber, final int pageSize, final Search search) { return this.search(TransactionDao.TRANSFORM_NONE, pageNumber, pageSize, search); } /** * {@inheritDoc} */ @Override public Set<?> search(final int transform, final Search search) { try { final PropertySearch propertySearch = new PropertySearch(this.getSession(false), TransactionImpl.class, search); final Set<?> results = propertySearch.executeAsSet(); this.transformEntities(transform, results); return results; } catch (HibernateException ex) { throw super.convertHibernateAccessException(ex); } } /** * {@inheritDoc} */ @Override @SuppressWarnings("unchecked") public Set<Transaction> search(final Search search) { return (Set<Transaction>) this.search(TransactionDao.TRANSFORM_NONE, search); } /** * Executes and returns the given Hibernate queryObject as a {@link PaginationResult} instance. * @param queryObject * @param transform * @param pageNumber * @param pageSize * @return PaginationResult */ @SuppressWarnings({ "unchecked" }) protected PaginationResult getPaginationResult(final Query queryObject, final int transform, int pageNumber, int pageSize) { try { final ScrollableResults scrollableResults = queryObject.scroll(); scrollableResults.last(); int totalCount = scrollableResults.getRowNumber(); totalCount = totalCount >= 0 ? totalCount + 1 : 0; if (pageNumber > 0 && pageSize > 0) { queryObject.setFirstResult(this.calculateFirstResult(pageNumber, pageSize)); queryObject.setMaxResults(pageSize); } // Unchecked transformation because Set object is reused, cannot be strongly typed. Set results = new LinkedHashSet(queryObject.list()); transformEntities(transform, results); return new PaginationResult(results.toArray(new Object[results.size()]), totalCount); } catch (HibernateException ex) { throw super.convertHibernateAccessException(ex); } } // spring-hibernate-dao-base merge-point }