package io.ebeaninternal.server.query;

import io.ebean.QueryIterator;
import io.ebean.Version;
import io.ebean.bean.BeanCollection;
import io.ebean.bean.EntityBean;
import io.ebean.event.BeanFindController;
import io.ebeaninternal.api.SpiQuery;
import io.ebeaninternal.api.SpiTransaction;
import io.ebeaninternal.server.core.OrmQueryEngine;
import io.ebeaninternal.server.core.OrmQueryRequest;
import io.ebeaninternal.server.core.SpiResultSet;
import io.ebeaninternal.server.deploy.BeanDescriptor;
import io.ebeaninternal.server.persist.Binder;

import javax.persistence.PersistenceException;
import java.sql.SQLException;
import java.util.Collection;
import java.util.List;

Main Finder implementation.
/** * Main Finder implementation. */
public class DefaultOrmQueryEngine implements OrmQueryEngine {
Find using predicates
/** * Find using predicates */
private final CQueryEngine queryEngine; private final Binder binder;
Create the Finder.
/** * Create the Finder. */
public DefaultOrmQueryEngine(CQueryEngine queryEngine, Binder binder) { this.queryEngine = queryEngine; this.binder = binder; } @Override public <T> PersistenceException translate(OrmQueryRequest<T> request, String bindLog, String sql, SQLException e) { return queryEngine.translate(request, bindLog, sql, e); } @Override public boolean isMultiValueSupported(Class<?> cls) { return binder.isMultiValueSupported(cls); }
Flushes the jdbc batch by default unless explicitly turned off on the transaction.
/** * Flushes the jdbc batch by default unless explicitly turned off on the transaction. */
private <T> void flushJdbcBatchOnQuery(OrmQueryRequest<T> request) { SpiTransaction t = request.getTransaction(); if (t.isFlushOnQuery()) { // before we perform a query, we need to flush any // previous persist requests that are queued/batched. // The query may read data affected by those requests. t.flush(); } } @Override public <T> int delete(OrmQueryRequest<T> request) { flushJdbcBatchOnQuery(request); return queryEngine.delete(request); } @Override public <T> int update(OrmQueryRequest<T> request) { flushJdbcBatchOnQuery(request); return queryEngine.update(request); } @Override public <T> SpiResultSet findResultSet(OrmQueryRequest<T> request) { flushJdbcBatchOnQuery(request); return queryEngine.findResultSet(request); } @Override public <T> int findCount(OrmQueryRequest<T> request) { flushJdbcBatchOnQuery(request); return queryEngine.findCount(request); } @Override public <A> List<A> findIds(OrmQueryRequest<?> request) { flushJdbcBatchOnQuery(request); return queryEngine.findIds(request); } @Override public <A> List<A> findSingleAttributeList(OrmQueryRequest<?> request) { flushJdbcBatchOnQuery(request); return queryEngine.findSingleAttributeList(request); } @Override public <T> QueryIterator<T> findIterate(OrmQueryRequest<T> request) { // LIMITATION: You can not use QueryIterator to load bean cache flushJdbcBatchOnQuery(request); return queryEngine.findIterate(request); } @Override public <T> List<Version<T>> findVersions(OrmQueryRequest<T> request) { flushJdbcBatchOnQuery(request); return queryEngine.findVersions(request); } @Override public <T> BeanCollection<T> findMany(OrmQueryRequest<T> request) { flushJdbcBatchOnQuery(request); BeanFindController finder = request.getBeanFinder(); BeanCollection<T> result; if (finder != null && finder.isInterceptFindMany(request)) { // intercept this request result = finder.findMany(request); } else { result = queryEngine.findMany(request); } SpiQuery<T> query = request.getQuery(); if (request.isBeanCachePutMany()) { // load the individual beans into the bean cache BeanDescriptor<T> descriptor = request.getBeanDescriptor(); Collection<T> c = result.getActualDetails(); descriptor.cacheBeanPutAll(c); } request.mergeCacheHits(result); if (request.isQueryCachePut()) { // load the query result into the query cache result.setReadOnly(true); request.putToQueryCache(result); if (Boolean.FALSE.equals(query.isReadOnly())) { result = result.getShallowCopy(); } } return result; }
Find a single bean using its unique id.
/** * Find a single bean using its unique id. */
@Override public <T> T findId(OrmQueryRequest<T> request) { flushJdbcBatchOnQuery(request); BeanFindController finder = request.getBeanFinder(); T result; if (finder != null && finder.isInterceptFind(request)) { result = finder.find(request); } else { result = queryEngine.find(request); } if (result != null && request.isBeanCachePut()) { request.getBeanDescriptor().cacheBeanPut((EntityBean) result); } return result; } }