本文整理汇总了Java中net.sf.jsqlparser.statement.select.SelectItemVisitor类的典型用法代码示例。如果您正苦于以下问题:Java SelectItemVisitor类的具体用法?Java SelectItemVisitor怎么用?Java SelectItemVisitor使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。
SelectItemVisitor类属于net.sf.jsqlparser.statement.select包,在下文中一共展示了SelectItemVisitor类的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: execute
import net.sf.jsqlparser.statement.select.SelectItemVisitor; //导入依赖的package包/类
@Override
public Result execute() {
final MongoColumnsExpressionVisitor columnsExprVisitor = new MongoColumnsExpressionVisitor();
final ListIterator<SelectItem> iterator = select.getSelectItems().listIterator();
while (iterator.hasNext()) {
iterator.next().accept(new SelectItemVisitor() {
@Override
public void visit(AllColumns allColumns) {
selectAll = true;
}
@Override
public void visit(AllTableColumns allTableColumns) {
}
@Override
public void visit(SelectExpressionItem selectExpressionItem) {
selectExpressionItem.getExpression().accept(columnsExprVisitor);
}
});
}
BasicDBObject columnsExpr = columnsExprVisitor.getExpression();
if(!selectAll && !columnsExpr.containsField("_id")) {
columnsExpr.append("_id", 0);
}
MongoWhereExpressionVisitor whereExprVisitor = new MongoWhereExpressionVisitor();
Expression updateWhere = select.getWhere();
if (updateWhere != null) {
updateWhere.accept(whereExprVisitor);
}
DBCollection mongoCollection = MongoClient.getDatastore().getCollection(collection);
DBCursor cursor = mongoCollection.find(whereExprVisitor.getExpression(), columnsExpr);
List<DBObject> resultList = new ArrayList<DBObject>();
try {
while (cursor.hasNext()) {
resultList.add(cursor.next());
}
} finally {
cursor.close();
}
return new MongoResult<String>(JSON.serialize(resultList));
}