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

com.oceanbase.tools.dbbrowser.template.mysql.MySQLProcedureTemplate Maven / Gradle / Ivy

Go to download

db-browser is used to quickly access databases and manage various database objects.

There is a newer version: 1.2.0
Show newest version
/*
 * Copyright (c) 2023 OceanBase.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.oceanbase.tools.dbbrowser.template.mysql;

import java.util.List;
import java.util.Objects;
import java.util.stream.Collectors;

import org.apache.commons.collections4.CollectionUtils;
import org.apache.commons.lang3.Validate;

import com.oceanbase.tools.dbbrowser.model.DBPLParam;
import com.oceanbase.tools.dbbrowser.model.DBProcedure;
import com.oceanbase.tools.dbbrowser.model.DBRoutineDataNature;
import com.oceanbase.tools.dbbrowser.util.MySQLSqlBuilder;
import com.oceanbase.tools.dbbrowser.util.SqlBuilder;
import com.oceanbase.tools.dbbrowser.util.StringUtils;

/**
 * {@link MySQLProcedureTemplate}
 *
 * @author yh263208
 * @date 2022-02-22 17:38
 * @since db-browser-1.0.0-SNAPSHOT
 */
public class MySQLProcedureTemplate extends BaseMySQLPLTemplate {

    @Override
    public String generateCreateObjectTemplate(DBProcedure dbObject) {
        Validate.notBlank(dbObject.getProName(), "Procedure name can not be blank");
        SqlBuilder sqlBuilder = new MySQLSqlBuilder();
        sqlBuilder.append("create procedure ").identifier(dbObject.getProName()).append("(");
        List paramList = dbObject.getParams();
        if (CollectionUtils.isNotEmpty(paramList)) {
            sqlBuilder.append(paramList.stream().map(p -> "\n\t" + generateInOutString(p.getParamMode())
                    + " " + StringUtils.quoteMysqlIdentifier(p.getParamName())
                    + " " + p.getDataType())
                    .collect(Collectors.joining(",")));
        }
        sqlBuilder.append(")").line();

        if (Objects.nonNull(dbObject.getCharacteristic())) {
            if (Objects.nonNull(dbObject.getCharacteristic().getComment())) {
                sqlBuilder.space().append("COMMENT ").value(dbObject.getCharacteristic().getComment()).line();
            }
            if (Objects.nonNull(dbObject.getCharacteristic().getDeterministic())
                    && dbObject.getCharacteristic().getDeterministic()) {
                sqlBuilder.space().append("DETERMINISTIC").line();
            }
            if (Objects.nonNull(dbObject.getCharacteristic().getDataNature())) {
                switch (dbObject.getCharacteristic().getDataNature()) {
                    case CONTAINS_SQL:
                        sqlBuilder.space().append(DBRoutineDataNature.CONTAINS_SQL.getValue()).line();
                        break;
                    case NO_SQL:
                        sqlBuilder.space().append(DBRoutineDataNature.NO_SQL.getValue()).line();
                        break;
                    case READS_SQL:
                        sqlBuilder.space().append(DBRoutineDataNature.READS_SQL.getValue()).line();
                        break;
                    case MODIFIES_SQL:
                        sqlBuilder.space().append(DBRoutineDataNature.MODIFIES_SQL.getValue()).line();
                        break;
                }
            }
            if (Objects.nonNull(dbObject.getCharacteristic().getSqlSecurity())) {
                sqlBuilder.space().append("SQL SECURITY ").append(dbObject.getCharacteristic().getSqlSecurity()).line();
            }
        }

        sqlBuilder.append("begin")
                .append("\n\t-- Enter your procedure code")
                .append("\nend");
        return sqlBuilder.toString();
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy