com.easy.query.db2.func.DB2ConcatSQLFunction Maven / Gradle / Ivy
The newest version!
package com.easy.query.db2.func;
import com.easy.query.core.expression.parser.core.available.TableAvailable;
import com.easy.query.core.func.column.ColumnExpression;
import com.easy.query.core.func.def.AbstractExpressionSQLFunction;
import com.easy.query.core.util.EasyCollectionUtil;
import java.util.List;
/**
* create time 2023/10/11 22:45
* 文件说明
*
* @author xuejiaming
*/
public class DB2ConcatSQLFunction extends AbstractExpressionSQLFunction {
private final List columnExpressions;
public DB2ConcatSQLFunction(List concatExpressions) {
if (EasyCollectionUtil.isEmpty(concatExpressions)) {
throw new IllegalArgumentException("DB2ConcatSQLFunction columns empty");
}
this.columnExpressions = concatExpressions;
}
@Override
public String sqlSegment(TableAvailable defaultTable) {
Iterable params = EasyCollectionUtil.select(columnExpressions, (t, i) ->"{" + i + "}");
// return String.format("(%s)", String.join(" || ", params));
//// return String.format("%s", String.join(" || ", params));
return String.format("CONCAT(%s)", String.join(",", params));
}
@Override
public int paramMarks() {
return columnExpressions.size();
}
@Override
protected List getColumnExpressions() {
return columnExpressions;
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy