org.sagacity.sqltoy.plugins.function.impl.Decode Maven / Gradle / Ivy
/**
*
*/
package org.sagacity.sqltoy.plugins.function.impl;
import java.util.regex.Pattern;
import org.sagacity.sqltoy.plugins.function.IFunction;
import org.sagacity.sqltoy.utils.DataSourceUtils.DBType;
/**
* @project sqltoy-orm
* @description oracle decode函数
* @author zhongxuchen
* @version v1.0,Date:2013-1-2
*/
public class Decode extends IFunction {
private static Pattern regex = Pattern.compile("(?i)\\Wdecode\\(");
/*
* (non-Javadoc)
*
* @see org.sagacity.sqltoy.config.function.IFunction#regex()
*/
@Override
public Pattern regex() {
return regex;
}
@Override
public String dialects() {
return super.ALL;
}
/*
* (non-Javadoc)
*
* @see org.sagacity.sqltoy.config.function.IFunction#wrap(java.lang.String [])
*/
@Override
public String wrap(int dialect, String functionName, boolean hasArgs, String... args) {
if (args == null || args.length < 2) {
return super.IGNORE;
}
/*
* if (dialect == DBType.MYSQL || dialect == DBType.MYSQL8) { return
* wrapArgs("ELT", args); } else
*/
// oracle支持decode
if (dialect == DBType.ORACLE || dialect == DBType.DM || dialect == DBType.OCEANBASE
|| dialect == DBType.ORACLE11 || dialect == DBType.H2) {
return super.IGNORE;
}
// decode(param,a1,a11,a2,a21,other)
String param = args[0];
StringBuilder sql = new StringBuilder(" case ");
int loopSize = (args.length - 1) / 2;
for (int i = 0; i < loopSize; i++) {
sql.append(" when ").append(param).append("=").append(args[1 + i * 2]).append(" then ")
.append(args[1 + i * 2 + 1]);
}
sql.append(" else ").append(args[args.length - 1]);
sql.append(" end ");
return sql.toString();
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy