All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.fastchar.database.info.FastSqlInfo Maven / Gradle / Ivy

There is a newer version: 2.2.2
Show newest version
package com.fastchar.database.info;

import com.fastchar.core.FastBaseInfo;
import com.fastchar.core.FastChar;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.LinkedHashMap;
import java.util.List;

public class FastSqlInfo extends FastBaseInfo {

    private static final long serialVersionUID = 1881604396324620713L;

    public static FastSqlInfo newInstance() {
        return FastChar.getOverrides().newInstance(FastSqlInfo.class);
    }

    protected FastSqlInfo() {
    }

    private String type;//数据库类型
    private String sql;
    private boolean log = true;
    private List params = new ArrayList<>();
    private List children = new ArrayList<>();

    public Object[] toParams(){
        return params.toArray(new Object[]{});
    }

    public String getType() {
        return type;
    }

    public FastSqlInfo setType(String type) {
        this.type = type;
        return this;
    }

    public String getSql() {
        return sql;
    }

    public FastSqlInfo setSql(String sql) {
        this.sql = sql;
        return this;
    }

    public List getParams() {
        return params;
    }

    public FastSqlInfo setParams(List params) {
        this.params = params;
        return this;
    }

    public FastSqlInfo setParams(Object... params) {
        this.params = Arrays.asList(params);
        return this;
    }


    public List getChildren() {
        return children;
    }

    public FastSqlInfo setChildren(List children) {
        this.children = children;
        return this;
    }

    public boolean isLog() {
        return log;
    }

    public FastSqlInfo setLog(boolean log) {
        this.log = log;
        return this;
    }

    public String toStaticSql() {
        String newSql = sql;
        for (Object param : params) {
            newSql = newSql.replaceFirst("\\?", "'" + param + "'");
        }
        return newSql;
    }
}