use of org.apache.cayenne.ejbql.EJBQLBaseVisitor in project cayenne by apache.
the class EJBQLJoinAppender method ejbqlQualifierForEntityAndSubclasses.
private EJBQLExpression ejbqlQualifierForEntityAndSubclasses(Expression qualifier, String entityId) {
// parser only works on full queries, so prepend a dummy query and then strip it out...
String ejbqlChunk = qualifier.toEJBQL(entityId);
EJBQLExpression expression = EJBQLParserFactory.getParser().parse("DELETE FROM DUMMY WHERE " + ejbqlChunk);
final EJBQLExpression[] result = new EJBQLExpression[1];
expression.visit(new EJBQLBaseVisitor() {
@Override
public boolean visitWhere(EJBQLExpression expression) {
result[0] = expression.getChild(0);
return false;
}
});
return result[0];
}
use of org.apache.cayenne.ejbql.EJBQLBaseVisitor in project cayenne by apache.
the class EJBQLFromItem method getSyntheticId.
/**
* Returns an id generated from the entity name. It is used when no user-specified id
* exists.
*/
public String getSyntheticId() {
int len = getChildrenCount();
if (len < 1) {
return null;
}
final String[] entityNames = new String[1];
getChild(0).visit(new EJBQLBaseVisitor() {
@Override
public boolean visitIdentificationVariable(EJBQLExpression expression) {
entityNames[0] = expression.getText();
return false;
}
});
if (entityNames[0] == null) {
return null;
}
// id's are case insensitive, while entity names are. Using simple encoding to
// transform the entity name in such way that two entities that differ only in
// capitalization would produce different lowercase ids
StringBuilder id = new StringBuilder(entityNames[0].length() + 2);
for (int i = 0; i < entityNames[0].length(); i++) {
char c = entityNames[0].charAt(i);
if (Character.isUpperCase(c)) {
id.append('%').append(Character.toLowerCase(c));
} else {
id.append(c);
}
}
return id.toString();
}
use of org.apache.cayenne.ejbql.EJBQLBaseVisitor in project cayenne by apache.
the class EJBQLAction method performAction.
@Override
public void performAction(Connection connection, OperationObserver observer) throws SQLException, Exception {
EJBQLCompiledExpression compiledExpression = query.getExpression(dataNode.getEntityResolver());
final EJBQLTranslatorFactory translatorFactory = dataNode.getAdapter().getEjbqlTranslatorFactory();
final EJBQLTranslationContext context = new EJBQLTranslationContext(dataNode.getEntityResolver(), query, compiledExpression, translatorFactory, dataNode.getAdapter().getQuotingStrategy());
compiledExpression.getExpression().visit(new EJBQLBaseVisitor(false) {
@Override
public boolean visitSelect(EJBQLExpression expression) {
EJBQLExpressionVisitor visitor = translatorFactory.getSelectTranslator(context);
expression.visit(visitor);
return false;
}
@Override
public boolean visitDelete(EJBQLExpression expression) {
EJBQLExpressionVisitor visitor = translatorFactory.getDeleteTranslator(context);
expression.visit(visitor);
return false;
}
@Override
public boolean visitUpdate(EJBQLExpression expression) {
EJBQLExpressionVisitor visitor = translatorFactory.getUpdateTranslator(context);
expression.visit(visitor);
return false;
}
});
SQLTemplate sqlQuery = context.getQuery();
// update with metadata
QueryMetadata md = query.getMetaData(dataNode.getEntityResolver());
sqlQuery.setFetchLimit(md.getFetchLimit());
sqlQuery.setFetchOffset(md.getFetchOffset());
sqlQuery.setResult(compiledExpression.getResult());
sqlQuery.setPageSize(md.getPageSize());
if (md.getStatementFetchSize() != 0) {
sqlQuery.setStatementFetchSize(md.getStatementFetchSize());
}
actionFactory.sqlAction(sqlQuery).performAction(connection, observer);
}
Aggregations