本文整理汇总了Java中com.alibaba.druid.sql.ast.SQLObject.accept方法的典型用法代码示例。如果您正苦于以下问题:Java SQLObject.accept方法的具体用法?Java SQLObject.accept怎么用?Java SQLObject.accept使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类com.alibaba.druid.sql.ast.SQLObject
的用法示例。
在下文中一共展示了SQLObject.accept方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: eval
import com.alibaba.druid.sql.ast.SQLObject; //导入方法依赖的package包/类
public static Object eval(String dbType, SQLObject sqlObject, List<Object> parameters, boolean throwError) {
SQLEvalVisitor visitor = createEvalVisitor(dbType);
visitor.setParameters(parameters);
Object value;
if (sqlObject instanceof SQLValuableExpr) {
value = ((SQLValuableExpr) sqlObject).getValue();
} else {
sqlObject.accept(visitor);
value = getValue(sqlObject);
if (value == null) {
if (throwError && !sqlObject.getAttributes().containsKey(EVAL_VALUE)) {
throw new DruidRuntimeException("eval error : " + SQLUtils.toSQLString(sqlObject, dbType));
}
}
}
return value;
}
示例2: eval
import com.alibaba.druid.sql.ast.SQLObject; //导入方法依赖的package包/类
public static Object eval(String dbType, SQLObject sqlObject, List<Object> parameters, boolean throwError) {
ActionMySqlEvalVisitorImpl visitor = new ActionMySqlEvalVisitorImpl();
visitor.setParameters(parameters);
sqlObject.accept(visitor);
Object value = getValue(sqlObject);
if (value == null && throwError && !sqlObject.getAttributes().containsKey("eval.value")) {
throw new DruidRuntimeException("eval error : " + SQLUtils.toSQLString(sqlObject, dbType));
} else {
return value;
}
}
示例3: visitHandle
import com.alibaba.druid.sql.ast.SQLObject; //导入方法依赖的package包/类
/**
* 进行OR表达式的访问.
*
* @param sqlObject SQL对象
* @return OR访问节点
*/
public Optional<AbstractOrASTNode> visitHandle(final SQLObject sqlObject) {
reset();
sqlObject.accept(this);
postVisitHandle();
return Optional.fromNullable(orASTNode);
}