2
0
Fork 0

Removed old total fetch method.

This commit is contained in:
Willem Cazander 2014-08-24 12:49:32 +02:00
parent 5bbd8e4ef3
commit e14b484ca5
18 changed files with 77 additions and 190 deletions

View file

@ -23,9 +23,10 @@
package net.forwardfire.vasc.backend; package net.forwardfire.vasc.backend;
import java.io.Serializable; import java.io.Serializable;
import java.util.Map;
/** /**
* AbstractVascBackend.
*
* *
* @author Willem Cazander * @author Willem Cazander
* @version 1.0 Aug 2, 2007 * @version 1.0 Aug 2, 2007
@ -83,14 +84,6 @@ abstract public class AbstractVascBackend<DATA_OBJECT extends Serializable> impl
return false; return false;
} }
/**
* @see net.forwardfire.vasc.backend.VascBackend#fetchTotalExecuteSize(VascBackendState state)
*/
@Override
public long fetchTotalExecuteSize(VascBackendState state) {
return 0;
}
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#isSearchable() * @see net.forwardfire.vasc.backend.VascBackend#isSearchable()
*/ */
@ -131,22 +124,6 @@ abstract public class AbstractVascBackend<DATA_OBJECT extends Serializable> impl
return 0l; return 0l;
} }
/**
* @see net.forwardfire.vasc.backend.VascBackend#executePageSummary()
*/
@Override
public Map<String, Object> executePageSummary() {
return null;
}
/**
* @see net.forwardfire.vasc.backend.VascBackend#executeTotalSummary()
*/
@Override
public Map<String, Object> executeTotalSummary() {
return null;
}
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#hasPageSummary() * @see net.forwardfire.vasc.backend.VascBackend#hasPageSummary()
*/ */

View file

@ -35,7 +35,11 @@ import java.util.Map;
public final class DefaultVascBackendResult<DATA_OBJECT extends Serializable> extends AbstractVascBackendResult<DATA_OBJECT> { public final class DefaultVascBackendResult<DATA_OBJECT extends Serializable> extends AbstractVascBackendResult<DATA_OBJECT> {
public DefaultVascBackendResult(List<DATA_OBJECT> pageData) { public DefaultVascBackendResult(List<DATA_OBJECT> pageData) {
this(pageData,-1,null,null); this(pageData,-1);
}
public DefaultVascBackendResult(List<DATA_OBJECT> pageData,long totalSize) {
this(pageData,totalSize,null,null);
} }
public DefaultVascBackendResult(List<DATA_OBJECT> pageData, long totalSize, public DefaultVascBackendResult(List<DATA_OBJECT> pageData, long totalSize,

View file

@ -78,12 +78,6 @@ public interface VascBackend<DATA_OBJECT extends Serializable> {
*/ */
public boolean isPageable(); public boolean isPageable();
/**
* Returns the total amount of records.
* @return
*/
public long fetchTotalExecuteSize(VascBackendState state);
/** /**
* Defines if the backend supports pageing * Defines if the backend supports pageing
* @return * @return
@ -100,8 +94,6 @@ public interface VascBackend<DATA_OBJECT extends Serializable> {
public boolean hasPageSummary(); public boolean hasPageSummary();
public Map<String,Object> executePageSummary();
public boolean hasTotalSummary(); public boolean hasTotalSummary();
public Map<String,Object> executeTotalSummary();
} }

View file

@ -76,10 +76,12 @@ public class XpqlHibernateVascBackend<DATA_OBJECT extends Serializable> extends
return hibernateSessionProvider.getHibernateSession(); return hibernateSessionProvider.getHibernateSession();
} }
@SuppressWarnings("unchecked")
@Override @Override
public VascBackendResult<DATA_OBJECT> execute(VascBackendState state) throws VascBackendException { public VascBackendResult<DATA_OBJECT> execute(VascBackendState state) throws VascBackendException {
return new DefaultVascBackendResult<DATA_OBJECT>(executeList(state),fetchTotalExecuteSize(state));
}
private List<DATA_OBJECT> executeList(VascBackendState state) throws VascBackendException {
// Copy parameters // Copy parameters
for (String key:state.getDataParameterKeys()) { for (String key:state.getDataParameterKeys()) {
Object value = state.getDataParameter(key); Object value = state.getDataParameter(key);
@ -111,7 +113,7 @@ public class XpqlHibernateVascBackend<DATA_OBJECT extends Serializable> extends
List<DATA_OBJECT> data = q.list(); List<DATA_OBJECT> data = q.list();
s.getTransaction().commit(); s.getTransaction().commit();
return new DefaultVascBackendResult<DATA_OBJECT>(data); return data;
} finally { } finally {
if (s!=null) { if (s!=null) {
//em.close(); //em.close();
@ -203,11 +205,7 @@ public class XpqlHibernateVascBackend<DATA_OBJECT extends Serializable> extends
return true; return true;
} }
/** private long fetchTotalExecuteSize(VascBackendState state) {
* @see net.forwardfire.vasc.backend.VascBackend#fetchTotalExecuteSize(VascBackendState state)
*/
@Override
public long fetchTotalExecuteSize(VascBackendState state) {
Session s = getHibernateSession(); Session s = getHibernateSession();
try { try {
s.getTransaction().begin(); s.getTransaction().begin();

View file

@ -76,9 +76,13 @@ public class XpqlPersistanceVascBackend<DATA_OBJECT extends Serializable> extend
return entityManagerProvider.getEntityManager(); return entityManagerProvider.getEntityManager();
} }
@SuppressWarnings("unchecked")
@Override @Override
public VascBackendResult<DATA_OBJECT> execute(VascBackendState state) throws VascBackendException { public VascBackendResult<DATA_OBJECT> execute(VascBackendState state) throws VascBackendException {
return new DefaultVascBackendResult<DATA_OBJECT>(executeList(state),fetchTotalExecuteSize(state));
}
@SuppressWarnings("unchecked")
private List<DATA_OBJECT> executeList(VascBackendState state) throws VascBackendException {
// Copy parameters // Copy parameters
for (String key:state.getDataParameterKeys()) { for (String key:state.getDataParameterKeys()) {
@ -112,8 +116,7 @@ public class XpqlPersistanceVascBackend<DATA_OBJECT extends Serializable> extend
if (emTransaction) { if (emTransaction) {
em.getTransaction().commit(); em.getTransaction().commit();
} }
VascBackendResult<DATA_OBJECT> result = new DefaultVascBackendResult<DATA_OBJECT>(data); return data;
return result;
} finally { } finally {
if (em!=null) { if (em!=null) {
//em.close(); //em.close();
@ -206,11 +209,7 @@ public class XpqlPersistanceVascBackend<DATA_OBJECT extends Serializable> extend
return true; return true;
} }
/** private long fetchTotalExecuteSize(VascBackendState state) {
* @see net.forwardfire.vasc.backend.VascBackend#fetchTotalExecuteSize(VascBackendState state)
*/
@Override
public long fetchTotalExecuteSize(VascBackendState state) {
EntityManager em = getEntityManager(); EntityManager em = getEntityManager();
try { try {
Query q = em.createQuery(queryTotal.toPreparedSQL(queryTotal)); Query q = em.createQuery(queryTotal.toPreparedSQL(queryTotal));

View file

@ -141,11 +141,7 @@ public class MetaModelVascBackend extends AbstractVascBackend<Row> {
return true; return true;
} }
/** private long fetchTotalExecuteSize(VascBackendState state) {
* @see net.forwardfire.vasc.backend.AbstractVascBackend#fetchTotalExecuteSize(net.forwardfire.vasc.backend.VascBackendState)
*/
@Override
public long fetchTotalExecuteSize(VascBackendState state) {
Schema schema = dataContext.getDefaultSchema(); Schema schema = dataContext.getDefaultSchema();
Table t = schema.getTableByName(table); Table t = schema.getTableByName(table);
Query q = createFilterQuery(state,t,true); Query q = createFilterQuery(state,t,true);
@ -213,6 +209,10 @@ public class MetaModelVascBackend extends AbstractVascBackend<Row> {
@Override @Override
public VascBackendResult<Row> execute(VascBackendState state) throws VascBackendException { public VascBackendResult<Row> execute(VascBackendState state) throws VascBackendException {
return new DefaultVascBackendResult<Row>(executeList(state),fetchTotalExecuteSize(state));
}
private List<Row> executeList(VascBackendState state) throws VascBackendException {
Schema schema = dataContext.getDefaultSchema(); Schema schema = dataContext.getDefaultSchema();
Table t = schema.getTableByName(table); Table t = schema.getTableByName(table);
if (t==null) { if (t==null) {
@ -243,7 +243,7 @@ public class MetaModelVascBackend extends AbstractVascBackend<Row> {
DataSet ds = crudDataContext.executeQuery(q); DataSet ds = crudDataContext.executeQuery(q);
result.addAll(ds.toRows()); result.addAll(ds.toRows());
ds.close(); ds.close();
return new DefaultVascBackendResult<Row>(result); return result;
} }
DataSet ds = dataContext.executeQuery(q); DataSet ds = dataContext.executeQuery(q);
@ -261,7 +261,7 @@ public class MetaModelVascBackend extends AbstractVascBackend<Row> {
} }
ds.close(); ds.close();
return new DefaultVascBackendResult<Row>(result); return result;
} }
@Override @Override

View file

@ -85,11 +85,7 @@ public class MongodbVascBackend extends AbstractVascBackend<BasicDBObject> {
return true; return true;
} }
/** private long fetchTotalExecuteSize(VascBackendState state) {
* @see net.forwardfire.vasc.backend.AbstractVascBackend#fetchTotalExecuteSize(net.forwardfire.vasc.backend.VascBackendState)
*/
@Override
public long fetchTotalExecuteSize(VascBackendState state) {
DBCollection coll = getDBCollection(); DBCollection coll = getDBCollection();
DBObject query = createFilterQuery(state); DBObject query = createFilterQuery(state);
long result = coll.count(query); long result = coll.count(query);
@ -108,6 +104,10 @@ public class MongodbVascBackend extends AbstractVascBackend<BasicDBObject> {
@Override @Override
public VascBackendResult<BasicDBObject> execute(VascBackendState state) throws VascBackendException { public VascBackendResult<BasicDBObject> execute(VascBackendState state) throws VascBackendException {
return new DefaultVascBackendResult<BasicDBObject>(executeList(state),fetchTotalExecuteSize(state));
}
private List<BasicDBObject> executeList(VascBackendState state) throws VascBackendException {
DBCollection coll = getDBCollection(); DBCollection coll = getDBCollection();
DBObject query = createFilterQuery(state); DBObject query = createFilterQuery(state);
DBCursor cur = coll.find(query); DBCursor cur = coll.find(query);
@ -120,7 +120,7 @@ public class MongodbVascBackend extends AbstractVascBackend<BasicDBObject> {
DBObject row = cur.next(); DBObject row = cur.next();
result.add((BasicDBObject)row); result.add((BasicDBObject)row);
} }
return new DefaultVascBackendResult<BasicDBObject>(result); return result;
} }
@Override @Override

View file

@ -23,7 +23,6 @@
package net.forwardfire.vasc.backend.proxy; package net.forwardfire.vasc.backend.proxy;
import java.io.Serializable; import java.io.Serializable;
import java.util.Map;
import net.forwardfire.vasc.backend.VascBackend; import net.forwardfire.vasc.backend.VascBackend;
import net.forwardfire.vasc.backend.VascBackendException; import net.forwardfire.vasc.backend.VascBackendException;
@ -94,14 +93,6 @@ abstract public class AbstractVascBackendProxy implements VascBackendProxy {
return backend.isReadOnly(); return backend.isReadOnly();
} }
/**
* @see net.forwardfire.vasc.backend.VascBackend#fetchTotalExecuteSize(VascBackendState state)
*/
@Override
public long fetchTotalExecuteSize(VascBackendState state) {
return backend.fetchTotalExecuteSize(state);
}
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#isSortable() * @see net.forwardfire.vasc.backend.VascBackend#isSortable()
*/ */
@ -215,22 +206,6 @@ abstract public class AbstractVascBackendProxy implements VascBackendProxy {
return backend.isRecordMoveable(); return backend.isRecordMoveable();
} }
/**
* @see net.forwardfire.vasc.backend.VascBackend#executePageSummary()
*/
@Override
public Map<String, Object> executePageSummary() {
return backend.executePageSummary();
}
/**
* @see net.forwardfire.vasc.backend.VascBackend#executeTotalSummary()
*/
@Override
public Map<String, Object> executeTotalSummary() {
return backend.executeTotalSummary();
}
/** /**
* @see net.forwardfire.vasc.backend.VascBackend#hasPageSummary() * @see net.forwardfire.vasc.backend.VascBackend#hasPageSummary()
*/ */

View file

@ -38,7 +38,6 @@ import net.forwardfire.vasc.backend.VascBackendState;
*/ */
public class VascBackendProxyCache extends AbstractVascBackendProxy { public class VascBackendProxyCache extends AbstractVascBackendProxy {
private Long records = null;
private VascBackendResult<Serializable> data = null; private VascBackendResult<Serializable> data = null;
private String searchString = null; private String searchString = null;
private Map<String,Object> dataState = null; private Map<String,Object> dataState = null;
@ -139,15 +138,6 @@ public class VascBackendProxyCache extends AbstractVascBackendProxy {
return data; return data;
} }
@Override
public long fetchTotalExecuteSize(VascBackendState state) {
boolean changed = isStateChanged(state);
if (records==null | changed) {
records = backend.fetchTotalExecuteSize(state);
}
return records;
}
/** /**
* @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#delete(java.lang.Object) * @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#delete(java.lang.Object)
*/ */

View file

@ -147,17 +147,6 @@ public class VascBackendProxyEventExecutor extends AbstractVascBackendProxy {
return result; return result;
} }
/**
* @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#fetchTotalExecuteSize(net.forwardfire.vasc.backend.VascBackendState)
*/
@Override
public long fetchTotalExecuteSize(VascBackendState state) {
fireVascEvent(VascBackendEventType.PRE_TOTAL_EXECUTE_SIZE,state);
Long result = super.fetchTotalExecuteSize(state);
fireVascEvent(VascBackendEventType.POST_TOTAL_EXECUTE_SIZE,result);
return result;
}
/** /**
* @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#merge(java.lang.Object) * @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#merge(java.lang.Object)
*/ */

View file

@ -41,7 +41,6 @@ import net.forwardfire.vasc.core.VascEntry;
*/ */
public class VascBackendProxyFilter extends AbstractVascBackendProxy { public class VascBackendProxyFilter extends AbstractVascBackendProxy {
private long records = 0;
private List<VascProxyFilter> filters = null; private List<VascProxyFilter> filters = null;
/** /**
@ -97,12 +96,6 @@ public class VascBackendProxyFilter extends AbstractVascBackendProxy {
} }
} }
} }
records = search.size(); return new DefaultVascBackendResult<Serializable>(search,search.size());
return new DefaultVascBackendResult<Serializable>(search);
}
@Override
public long fetchTotalExecuteSize(VascBackendState state) {
return records;
} }
} }

View file

@ -39,8 +39,6 @@ import net.forwardfire.vasc.backend.VascBackendState;
*/ */
public class VascBackendProxyPaged extends AbstractVascBackendProxy { public class VascBackendProxyPaged extends AbstractVascBackendProxy {
private long records = 0;
/** /**
* @see java.lang.Object#clone() * @see java.lang.Object#clone()
*/ */
@ -77,7 +75,6 @@ public class VascBackendProxyPaged extends AbstractVascBackendProxy {
VascBackendResult<Serializable> allData = backend.execute(state); VascBackendResult<Serializable> allData = backend.execute(state);
int pageSize = state.getPageSize(); int pageSize = state.getPageSize();
if (pageSize==0) { if (pageSize==0) {
records = allData.getPageData().size();
return allData; return allData;
} }
List<Serializable> paged = new ArrayList<Serializable>(state.getPageSize()); List<Serializable> paged = new ArrayList<Serializable>(state.getPageSize());
@ -90,12 +87,6 @@ public class VascBackendProxyPaged extends AbstractVascBackendProxy {
Serializable o = allData.getPageData().get(i); Serializable o = allData.getPageData().get(i);
paged.add(o); paged.add(o);
} }
records = allData.getPageData().size(); return new DefaultVascBackendResult<Serializable>(paged,allData.getPageData().size());
return new DefaultVascBackendResult<Serializable>(paged);
}
@Override
public long fetchTotalExecuteSize(VascBackendState state) {
return records;
} }
} }

View file

@ -137,9 +137,4 @@ public class VascBackendProxySearch extends AbstractVascBackendProxy {
//records = search.size(); //records = search.size();
return new DefaultVascBackendResult<Serializable>(search); return new DefaultVascBackendResult<Serializable>(search);
} }
@Override
public long fetchTotalExecuteSize(VascBackendState state) {
return backend.fetchTotalExecuteSize(state);
}
} }

View file

@ -69,17 +69,6 @@ public class VascBackendProxyTimerLogger extends AbstractVascBackendProxy {
} }
} }
@Override
public long fetchTotalExecuteSize(VascBackendState state) {
long t1 = System.currentTimeMillis();
try {
return backend.fetchTotalExecuteSize(state);
} finally {
long t2 = System.currentTimeMillis();
logger.log(logLevel,"vasc-fetchTotalExecuteSize backend: "+getId()+" in "+(t2-t1)+" ms");
}
}
/** /**
* @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#doRecordMoveDownById(net.forwardfire.vasc.backend.VascBackendState, java.lang.Object) * @see net.forwardfire.vasc.backend.proxy.AbstractVascBackendProxy#doRecordMoveDownById(net.forwardfire.vasc.backend.VascBackendState, java.lang.Object)
*/ */

View file

@ -42,7 +42,6 @@ public interface VascEntryBackendEventListener extends Serializable {
PRE_DELETE, PRE_DELETE,
PRE_PROVIDE_FIELD_VALUE, PRE_PROVIDE_FIELD_VALUE,
PRE_PROVIDE_RECORD_CREATOR, PRE_PROVIDE_RECORD_CREATOR,
PRE_TOTAL_EXECUTE_SIZE,
PRE_MOVE_DOWN, PRE_MOVE_DOWN,
PRE_MOVE_UP, PRE_MOVE_UP,
@ -52,7 +51,6 @@ public interface VascEntryBackendEventListener extends Serializable {
POST_DELETE, POST_DELETE,
POST_PROVIDE_FIELD_VALUE, POST_PROVIDE_FIELD_VALUE,
POST_PROVIDE_RECORD_CREATOR, POST_PROVIDE_RECORD_CREATOR,
POST_TOTAL_EXECUTE_SIZE,
POST_MOVE_DOWN, POST_MOVE_DOWN,
POST_MOVE_UP POST_MOVE_UP
} }

View file

@ -65,8 +65,7 @@ public class SetParameterBackendListener implements VascEntryBackendEventListene
VascBackendEventType.PRE_MERGE, VascBackendEventType.PRE_MERGE,
VascBackendEventType.PRE_MOVE_DOWN, VascBackendEventType.PRE_MOVE_DOWN,
VascBackendEventType.PRE_MOVE_UP, VascBackendEventType.PRE_MOVE_UP,
VascBackendEventType.PRE_PERSIST, VascBackendEventType.PRE_PERSIST
VascBackendEventType.PRE_TOTAL_EXECUTE_SIZE
}; };
} }

View file

@ -27,6 +27,7 @@ import java.util.Date;
import java.util.logging.Logger; import java.util.logging.Logger;
import net.forwardfire.vasc.backend.VascBackendException; import net.forwardfire.vasc.backend.VascBackendException;
import net.forwardfire.vasc.backend.VascBackendResult;
import net.forwardfire.vasc.backend.VascBackendState; import net.forwardfire.vasc.backend.VascBackendState;
import net.forwardfire.vasc.backend.proxy.VascProxyFilter; import net.forwardfire.vasc.backend.proxy.VascProxyFilter;
import net.forwardfire.vasc.core.VascEntry; import net.forwardfire.vasc.core.VascEntry;
@ -225,25 +226,25 @@ public class DefaultVascFrontendActions implements VascFrontendActions {
} }
} }
// Always update total records VascBackendResult<Serializable> result;
Long total = entry.getVascFrontendController().getVascEntryState().getVascBackend().fetchTotalExecuteSize(backendState); try {
entry.getVascFrontendController().getVascEntryState().setTotalBackendRecords(total); result = entry.getVascFrontendController().getVascEntryState().getVascBackend().execute(backendState);
} catch (VascBackendException ve) {
throw new VascFrontendException(ve);
}
// Set data in frontend
entry.getVascFrontendController().getVascEntryState().setEntryDataList(result.getPageData());
entry.getVascFrontendController().getVascEntryState().setTotalBackendRecords(result.getTotalSize());
// check if we need to change the current page if table size if changed in between // check if we need to change the current page if table size if changed in between
int pages = new Long(total/backendState.getPageSize()).intValue(); int pages = new Long(result.getTotalSize()/backendState.getPageSize()).intValue();
if (backendState.getPageIndex() > pages) { if (backendState.getPageIndex() > pages) {
backendState.setPageIndex(pages); backendState.setPageIndex(pages);
} }
try { // Fire event post read
// Execute to get data. entry.getVascFrontendController().fireVascFrontendEvent(entry,VascEntryFrontendEventListener.VascFrontendEventType.POST_READ, null);
entry.getVascFrontendController().getVascEntryState().setEntryDataList(entry.getVascFrontendController().getVascEntryState().getVascBackend().execute(backendState).getPageData());
// Fire event post read
entry.getVascFrontendController().fireVascFrontendEvent(entry,VascEntryFrontendEventListener.VascFrontendEventType.POST_READ, null);
} catch (VascBackendException ve) {
throw new VascFrontendException(ve);
}
} }
@Override @Override

View file

@ -174,9 +174,6 @@ public class VascExportServlet extends HttpServlet {
VascEntryLocal ve = (VascEntryLocal)vc.getVascEntryConfigController().configVascEntry(vc, entryId); VascEntryLocal ve = (VascEntryLocal)vc.getVascEntryConfigController().configVascEntry(vc, entryId);
vc.getVascEntryConfigController().configVascFrontendController(vc, ve); vc.getVascEntryConfigController().configVascFrontendController(vc, ve);
// Update total every time first
Long total = ve.getVascFrontendController().getVascEntryState().getVascBackend().fetchTotalExecuteSize(ve.getVascFrontendController().getVascEntryState().getVascBackendState());
ve.getVascFrontendController().getVascEntryState().setTotalBackendRecords(total);
VascEntryExport ex = vc.getVascEntryConfigController().getVascEntryExporterById(exportId); VascEntryExport ex = vc.getVascEntryConfigController().getVascEntryExporterById(exportId);
VascEntryExportWriter exw = ex.createExportWriter(); VascEntryExportWriter exw = ex.createExportWriter();
exw.doInit(ex, ve); exw.doInit(ex, ve);