1 В избранное 0 Ответвления 0

OSCHINA-MIRROR/troyzhxu-bean-searcher

Клонировать/Скачать
FieldOp.java 2.3 КБ
Копировать Редактировать Web IDE Исходные данные Просмотреть построчно История
Troy Отправлено 16.10.2022 12:47 fc1328c
package cn.zhxu.bs;
import java.util.List;
/**
* 字段运算符
* @author Troy.Zhou @ 2022-01-18
* @since v3.3.0
*/
public interface FieldOp {
/**
* 该运算符的名称
* @return 该运算符的名称
*/
String name();
/**
* 猜测该运算符的名字
* @param name 猜测名称
* @return 是否正确
*/
boolean isNamed(String name);
/**
* @return 该运算符是否不需要参数即可运算
*/
default boolean lonely() {
return false;
}
/**
* 该运算符是否非公开的,若是非公开的,则只能在参数构建器中使用它
* 只有公开的运算符才能加入运算符池 {@link FieldOpPool}
* @return 是否非公开的
* @since v3.8.0
*/
default boolean isNonPublic() {
return false;
}
/**
* 执行该运算符
* @param sqlBuilder SQL 构建器
* @param opPara 运算参数
* @return 该运算符产生的 JDBC 参数列表
*/
List<Object> operate(StringBuilder sqlBuilder, OpPara opPara);
/**
* 判断两个运算符是否是同一个类型
* @param another 另一个运算符
* @return 是否是同一个
*/
default boolean sameTo(FieldOp another) {
if (another == null) {
return false;
}
if (another == this) {
return true;
}
return isNamed(another.name()) || another.isNamed(name());
}
/**
* 运算参数
*/
class OpPara {
final FieldSqlGetter fieldSqlGetter;
final boolean ignoreCase;
final Object[] values;
public OpPara(FieldSqlGetter fieldSqlGetter, boolean ignoreCase, Object[] values) {
this.fieldSqlGetter = fieldSqlGetter;
this.ignoreCase = ignoreCase;
this.values = values;
}
public interface FieldSqlGetter {
SqlWrapper<Object> get(String fieldName);
}
public SqlWrapper<Object> getFieldSql() {
return fieldSqlGetter.get(null);
}
public SqlWrapper<Object> getFieldSql(String field) {
return fieldSqlGetter.get(field);
}
public boolean isIgnoreCase() {
return ignoreCase;
}
public Object[] getValues() {
return values;
}
}
}

Опубликовать ( 0 )

Вы можете оставить комментарий после Вход в систему

1
https://api.gitlife.ru/oschina-mirror/troyzhxu-bean-searcher.git
git@api.gitlife.ru:oschina-mirror/troyzhxu-bean-searcher.git
oschina-mirror
troyzhxu-bean-searcher
troyzhxu-bean-searcher
dev