package org.jboss.ejb.plugins.cmp.jdbc;
import org.jboss.ejb.plugins.cmp.jdbc.bridge.JDBCEntityBridge;
import org.jboss.ejb.plugins.cmp.jdbc.metadata.JDBCQueryMetaData;
import org.jboss.ejb.plugins.cmp.jdbc.metadata.JDBCReadAheadMetaData;
import org.jboss.ejb.plugins.cmp.jdbc.metadata.JDBCTypeMappingMetaData;
import org.jboss.ejb.plugins.cmp.jdbc.metadata.JDBCFunctionMappingMetaData;
import org.jboss.ejb.EntityEnterpriseContext;
import org.jboss.ejb.GenericEntityObjectFactory;
import org.jboss.deployment.DeploymentException;
import javax.ejb.FinderException;
import java.util.Collection;
import java.util.Collections;
import java.util.List;
import java.lang.reflect.Method;
public final class JDBCFindByPrimaryKeyQuery extends JDBCAbstractQueryCommand
{
private JDBCStoreManager manager;
private boolean rowLocking;
public JDBCFindByPrimaryKeyQuery(JDBCStoreManager manager, JDBCQueryMetaData q)
throws DeploymentException
{
super(manager, q);
this.manager = manager;
rowLocking = manager.getMetaData().hasRowLocking();
JDBCEntityBridge entity = (JDBCEntityBridge) manager.getEntityBridge();
JDBCTypeMappingMetaData typeMapping = this.manager.getJDBCTypeFactory().getTypeMapping();
AliasManager aliasManager = new AliasManager(
typeMapping.getAliasHeaderPrefix(),
typeMapping.getAliasHeaderSuffix(),
typeMapping.getAliasMaxLength()
);
String alias = aliasManager.getAlias(entity.getEntityName());
StringBuffer select = new StringBuffer(200);
SQLUtil.getColumnNamesClause(entity.getPrimaryKeyFields(), alias, select);
StringBuffer from = new StringBuffer();
from.append(entity.getQualifiedTableName())
.append(' ')
.append(alias);
JDBCReadAheadMetaData readAhead = q.getReadAhead();
if(readAhead.isOnFind())
{
setEagerLoadGroup(readAhead.getEagerLoadGroup());
if(getEagerLoadMask() != null)
{
SQLUtil.appendColumnNamesClause(entity.getTableFields(), getEagerLoadMask(), alias, select);
List onFindCMRList = JDBCAbstractQueryCommand.getLeftJoinCMRNodes(
entity, entity.getQualifiedTableName(), readAhead.getLeftJoins());
if(!onFindCMRList.isEmpty())
{
setOnFindCMRList(onFindCMRList);
JDBCAbstractQueryCommand.leftJoinCMRNodes(alias, onFindCMRList, aliasManager, from);
JDBCAbstractQueryCommand.appendLeftJoinCMRColumnNames(onFindCMRList, aliasManager, select);
}
}
}
StringBuffer where = new StringBuffer();
SQLUtil.getWhereClause(entity.getPrimaryKeyFields(), alias, where);
StringBuffer sql = new StringBuffer(300);
if(rowLocking && readAhead.isOnFind() && getEagerLoadMask() != null)
{
JDBCFunctionMappingMetaData rowLockingTemplate = typeMapping.getRowLockingTemplate();
rowLockingTemplate.getFunctionSql(
new Object[]{
select,
from,
where.length() == 0 ? null : where,
null },
sql
);
}
else
{
sql.append(SQLUtil.SELECT)
.append(select)
.append(SQLUtil.FROM)
.append(from)
.append(SQLUtil.WHERE)
.append(where);
}
setSQL(sql.toString());
setParameterList(QueryParameter.createPrimaryKeyParameters(0, entity));
}
public Collection execute(Method finderMethod, Object[] args, EntityEnterpriseContext ctx, GenericEntityObjectFactory factory)
throws FinderException
{
if(manager.getReadAheadCache().getPreloadDataMap(args[0], false) != null)
{
final Object ejbObject = factory.getEntityEJBObject(args[0]);
return Collections.singletonList(ejbObject);
}
return super.execute(finderMethod, args, ctx, factory);
}
}