db.sql.api.impl.cmd.dbFun.mysql.JsonExtract Maven / Gradle / Ivy
package db.sql.api.impl.cmd.dbFun.mysql;
import db.sql.api.Cmd;
import db.sql.api.SqlBuilderContext;
import db.sql.api.impl.cmd.dbFun.BasicFunction;
import db.sql.api.impl.tookit.SqlConst;
public class JsonExtract extends BasicFunction {
private final String[] paths;
public JsonExtract(Cmd key, String[] paths) {
super(SqlConst.JSON_EXTRACT, key);
this.paths = paths;
}
@Override
public StringBuilder functionSql(Cmd module, Cmd parent, SqlBuilderContext context, StringBuilder sqlBuilder) {
sqlBuilder.append(operator).append(SqlConst.BRACKET_LEFT);
;
this.key.sql(module, this, context, sqlBuilder);
for (String path : paths) {
sqlBuilder.append(SqlConst.DELIMITER);
sqlBuilder.append(SqlConst.SINGLE_QUOT);
sqlBuilder.append(path);
sqlBuilder.append(SqlConst.SINGLE_QUOT);
}
sqlBuilder.append(SqlConst.BRACKET_RIGHT);
return sqlBuilder;
}
}