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

org.anyline.data.jdbc.adapter.init.MySQLGenusAdapter Maven / Gradle / Ivy

There is a newer version: 8.7.2-20240916
Show newest version
/*
 * Copyright 2006-2023 www.anyline.org
 *
 * 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 org.anyline.data.jdbc.adapter.init;

import org.anyline.data.entity.Join;
import org.anyline.data.jdbc.adapter.init.alias.MySQLGenusTypeMetadataAlias;
import org.anyline.data.param.ConfigStore;
import org.anyline.data.param.init.DefaultConfigStore;
import org.anyline.data.prepare.RunPrepare;
import org.anyline.data.prepare.auto.TablePrepare;
import org.anyline.data.prepare.auto.init.VirtualTablePrepare;
import org.anyline.data.run.*;
import org.anyline.data.runtime.DataRuntime;
import org.anyline.entity.*;
import org.anyline.entity.authorize.Privilege;
import org.anyline.entity.authorize.User;
import org.anyline.exception.NotSupportException;
import org.anyline.metadata.*;
import org.anyline.metadata.refer.*;
import org.anyline.metadata.type.TypeMetadata;
import org.anyline.util.*;
import org.anyline.util.regular.RegularUtil;

import java.lang.reflect.Array;
import java.util.*;

public abstract class MySQLGenusAdapter extends AbstractJDBCAdapter {
    public MySQLGenusAdapter() {
        super();
        MetadataReferHolder.reg(type(), TypeMetadata.CATEGORY.CHAR, new TypeMetadata.Refer("CHARACTER_MAXIMUM_LENGTH", null, null, 0, 1, 1));
        MetadataReferHolder.reg(type(), TypeMetadata.CATEGORY.TEXT, new TypeMetadata.Refer("CHARACTER_MAXIMUM_LENGTH", null, null, 1, 1, 1));
        MetadataReferHolder.reg(type(), TypeMetadata.CATEGORY.BOOLEAN, new TypeMetadata.Refer("CHARACTER_MAXIMUM_LENGTH", null, null, 1,1, 1));
        MetadataReferHolder.reg(type(), TypeMetadata.CATEGORY.BYTES, new TypeMetadata.Refer("CHARACTER_MAXIMUM_LENGTH", null, null, 0, 1, 1));
        MetadataReferHolder.reg(type(), TypeMetadata.CATEGORY.BLOB, new TypeMetadata.Refer("CHARACTER_MAXIMUM_LENGTH", null, null, 1,1,1));
        MetadataReferHolder.reg(type(), TypeMetadata.CATEGORY.INT, new TypeMetadata.Refer("CHARACTER_MAXIMUM_LENGTH", "NUMERIC_PRECISION", null, 1, 1, 1));
        MetadataReferHolder.reg(type(), TypeMetadata.CATEGORY.FLOAT, new TypeMetadata.Refer("CHARACTER_MAXIMUM_LENGTH", "NUMERIC_PRECISION", "NUMERIC_SCALE", 1, 2, 2));
        MetadataReferHolder.reg(type(), TypeMetadata.CATEGORY.DATE, new TypeMetadata.Refer("CHARACTER_MAXIMUM_LENGTH", null, null, 1, 1, 1));
        MetadataReferHolder.reg(type(), TypeMetadata.CATEGORY.TIME, new TypeMetadata.Refer("CHARACTER_MAXIMUM_LENGTH", null, null, 1, 1, 1));
        MetadataReferHolder.reg(type(), TypeMetadata.CATEGORY.DATETIME, new TypeMetadata.Refer("CHARACTER_MAXIMUM_LENGTH", null, null, 1, 1, 1));
        MetadataReferHolder.reg(type(), TypeMetadata.CATEGORY.TIMESTAMP, new TypeMetadata.Refer("CHARACTER_MAXIMUM_LENGTH", null, null, 1, 1, 1));
        MetadataReferHolder.reg(type(), TypeMetadata.CATEGORY.COLLECTION, new TypeMetadata.Refer("CHARACTER_MAXIMUM_LENGTH", null, null, 1, 1, 1));
        MetadataReferHolder.reg(type(), TypeMetadata.CATEGORY.GEOMETRY, new TypeMetadata.Refer("CHARACTER_MAXIMUM_LENGTH", null, null, 1, 1, 1));
        MetadataReferHolder.reg(type(), TypeMetadata.CATEGORY.OTHER, new TypeMetadata.Refer("CHARACTER_MAXIMUM_LENGTH", null, null, 1, 1, 1));

        for(MySQLGenusTypeMetadataAlias alias:MySQLGenusTypeMetadataAlias.values()) {
            reg(alias);
            alias(alias.name(), alias.standard());
        }

    }

    @Override
    public boolean supportCatalog() {
        return false;
    }

    @Override
    public boolean supportSchema() {
        return super.supportSchema();
    }

    @Override
    public  String columnAliasGuidd() {
        return " AS ";
    }
    @Override
    public  String tableAliasGuidd() {
        return " AS ";
    }
    private static Map types = new HashMap<>();
    static {
        types.put(Table.TYPE.NORMAL, "BASE TABLE");
        types.put(Table.TYPE.VIEW, "VIEW");
        types.put(View.TYPE.NORMAL, "VIEW");
        types.put(Metadata.TYPE.TABLE, "BASE TABLE");
        types.put(Metadata.TYPE.VIEW, "VIEW");
    }

    @Override
    public String name(Type type) {
        return types.get(type);
    }

    /* *****************************************************************************************************************
     *
     *                                                     DML
     *
     * =================================================================================================================
     * INSERT            : 插入
     * UPDATE            : 更新
     * SAVE                : 根据情况插入或更新
     * QUERY            : 查询(RunPrepare/XML/TABLE/VIEW/PROCEDURE)
     * EXISTS            : 是否存在
     * COUNT            : 统计
     * EXECUTE            : 执行(原生SQL及存储过程)
     * DELETE            : 删除
     *
     ******************************************************************************************************************/
    /* *****************************************************************************************************************
     *                                                     INSERT
     * -----------------------------------------------------------------------------------------------------------------
     * [调用入口]
     * long insert(DataRuntime runtime, String random, int batch, String dest, Object data, ConfigStore configs, List columns)
     * [命令合成]
     * public Run buildInsertRun(DataRuntime runtime, int batch, Table dest, Object obj, ConfigStore configs, List columns)
     * public void fillInsertContent(DataRuntime runtime, Run run, Table dest, DataSet set, ConfigStore configs, LinkedHashMap columns)
     * public void fillInsertContent(DataRuntime runtime, Run run, Table dest, Collection list, ConfigStore configs, LinkedHashMap columns)
     * public LinkedHashMap confirmInsertColumns(DataRuntime runtime, String dest, Object obj, ConfigStore configs, List columns, boolean batch)
     * public String batchInsertSeparator()
     * public boolean supportInsertPlaceholder()
     * protected Run createInsertRun(DataRuntime runtime, Table dest, Object obj, ConfigStore configs, List columns)
     * protected Run createInsertRunFromCollection(DataRuntime runtime, int batch, Table dest, Collection list, ConfigStore configs, List columns)
     * public String generatedKey()
     * [命令执行]
     * long insert(DataRuntime runtime, String random, Object data, ConfigStore configs, Run run, String[] pks);
     * long insert(DataRuntime runtime, String random, Object data, ConfigStore configs, Run run);
     ******************************************************************************************************************/

    /**
     * insert [调用入口]
* 执行前根据主键生成器补充主键值, 执行完成后会补齐自增主键值 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param dest 表 如果不提供表名则根据data解析, 表名可以事实前缀<数据源名>表示切换数据源 * @param data 需要插入入的数据 * @param columns 需要插入的列,如果不指定则根据data或configs获取注意会受到ConfigTable中是否插入更新空值的几个配置项影响 * 列可以加前缀
* +:表示必须插入
* -:表示必须不插入
* ?:根据是否有值
* * 如果没有提供columns, 长度为0也算没有提供
* 则解析obj(遍历所有的属性工Key)获取insert列
* * 如果提供了columns则根据columns获取insert列
* * 但是columns中出现了添加前缀列, 则解析完columns后, 继续解析obj
* * 以上执行完后, 如果开启了ConfigTable.IS_AUTO_CHECK_METADATA=true
* 则把执行结果与表结构对比, 删除表中没有的列
* @return 影响行数 */ @Override public long insert(DataRuntime runtime, String random, int batch, Table dest, Object data, ConfigStore configs, List columns) { return super.insert(runtime, random, batch, dest, data, configs, columns); } /** * insert [命令合成]
* 填充inset命令内容(创建批量INSERT RunPrepare) * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param dest 表 如果不提供表名则根据data解析, 表名可以事实前缀<数据源名>表示切换数据源 * @param obj 需要插入的数据 * @param columns 需要插入的列,如果不指定则根据data或configs获取注意会受到ConfigTable中是否插入更新空值的几个配置项影响 * @return Run 最终执行命令 如JDBC环境中的 SQL 与 参数值 */ @Override public Run buildInsertRun(DataRuntime runtime, int batch, Table dest, Object obj, ConfigStore configs, List columns) { return super.buildInsertRun(runtime, batch, dest, obj, configs, columns); } /** * insert [命令合成-子流程]
* 填充inset命令内容(创建批量INSERT RunPrepare) * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param run 最终待执行的命令和参数(如JDBC环境中的SQL) * @param dest 表 如果不提供表名则根据data解析, 表名可以事实前缀<数据源名>表示切换数据源 * @param set 需要插入的数据集合 * @param columns 需要插入的列,如果不指定则根据data或configs获取注意会受到ConfigTable中是否插入更新空值的几个配置项影响 */ @Override public void fillInsertContent(DataRuntime runtime, Run run, Table dest, DataSet set, ConfigStore configs, LinkedHashMap columns) { super.fillInsertContent(runtime, run, dest, set, configs, columns); } /** * insert [命令合成-子流程]
* 填充inset命令内容(创建批量INSERT RunPrepare) * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param run 最终待执行的命令和参数(如JDBC环境中的SQL) * @param dest 表 如果不提供表名则根据data解析, 表名可以事实前缀<数据源名>表示切换数据源 * @param list 需要插入的数据集合 * @param columns 需要插入的列,如果不指定则根据data或configs获取注意会受到ConfigTable中是否插入更新空值的几个配置项影响 */ @Override public void fillInsertContent(DataRuntime runtime, Run run, Table dest, Collection list, ConfigStore configs, LinkedHashMap columns) { super.fillInsertContent(runtime, run, dest, list, configs, columns); } /** * insert [命令合成-子流程]
* 确认需要插入的列 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param dest 表 如果不提供表名则根据data解析, 表名可以事实前缀<数据源名>表示切换数据源 * @param obj Entity或DataRow * @param batch 是否批量,批量时不检测值是否为空 * @param columns 需要插入的列,如果不指定则根据data或configs获取注意会受到ConfigTable中是否插入更新空值的几个配置项影响 * 列可以加前缀
* +:表示必须插入
* -:表示必须不插入
* ?:根据是否有值
* * 如果没有提供columns, 长度为0也算没有提供
* 则解析obj(遍历所有的属性工Key)获取insert列
* * 如果提供了columns则根据columns获取insert列
* * 但是columns中出现了添加前缀列, 则解析完columns后, 继续解析obj
* * 以上执行完后, 如果开启了ConfigTable.IS_AUTO_CHECK_METADATA=true
* 则把执行结果与表结构对比, 删除表中没有的列
* @return List */ @Override public LinkedHashMap confirmInsertColumns(DataRuntime runtime, String dest, Object obj, ConfigStore configs, List columns, boolean batch) { return super.confirmInsertColumns(runtime, dest, obj, configs, columns, batch); } /** * insert [命令合成-子流程]
* 批量插入数据时, 多行数据之间分隔符 * @return String */ @Override public String batchInsertSeparator() { return ","; } /** * insert [命令合成-子流程]
* 插入数据时是否支持占位符 * @return boolean */ @Override public boolean supportInsertPlaceholder() { return true; } /** * insert [命令合成-子流程]
* 设置主键值 * @param obj obj * @param value value */ @Override protected void setPrimaryValue(Object obj, Object value) { super.setPrimaryValue(obj, value); } /** * insert [命令合成-子流程]
* 根据entity创建 INSERT RunPrepare由buildInsertRun调用 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param dest 表 如果不提供表名则根据data解析, 表名可以事实前缀<数据源名>表示切换数据源 * @param obj 数据 * @param columns 需要插入的列,如果不指定则根据data或configs获取注意会受到ConfigTable中是否插入更新空值的几个配置项影响 * @return Run 最终执行命令 如JDBC环境中的 SQL 与 参数值 */ @Override protected Run createInsertRun(DataRuntime runtime, Table dest, Object obj, ConfigStore configs, List columns) { return super.createInsertRun(runtime, dest, obj, configs, columns); } /** * insert [命令合成-子流程]
* 根据collection创建 INSERT RunPrepare由buildInsertRun调用 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param dest 表 如果不提供表名则根据data解析, 表名可以事实前缀<数据源名>表示切换数据源 * @param list 对象集合 * @param columns 需要插入的列,如果不指定则根据data或configs获取注意会受到ConfigTable中是否插入更新空值的几个配置项影响 * @return Run 最终执行命令 如JDBC环境中的 SQL 与 参数值 */ @Override protected Run createInsertRunFromCollection(DataRuntime runtime, int batch, Table dest, Collection list, ConfigStore configs, List columns) { return super.createInsertRunFromCollection(runtime, batch, dest, list, configs, columns); } /** * insert [after]
* 执行insert后返回自增主键的key * @return String */ @Override public String generatedKey() { return "GENERATED_KEY"; } /** * insert [命令执行] *
* 执行完成后会补齐自增主键值 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param data data * @param run 最终待执行的命令和参数(如JDBC环境中的SQL) * @param pks 需要返回的主键 * @return 影响行数 */ @Override public long insert(DataRuntime runtime, String random, Object data, ConfigStore configs, Run run, String[] pks) { return super.insert(runtime, random, data, configs, run, pks); } /* ***************************************************************************************************************** * UPDATE * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * long update(DataRuntime runtime, String random, int batch, String dest, Object data, ConfigStore configs, List columns) * [命令合成] * Run buildUpdateRun(DataRuntime runtime, int batch, String dest, Object obj, ConfigStore configs, List columns) * Run buildUpdateRunFromEntity(DataRuntime runtime, String dest, Object obj, ConfigStore configs, LinkedHashMap columns) * Run buildUpdateRunFromDataRow(DataRuntime runtime, String dest, DataRow row, ConfigStore configs, LinkedHashMap columns) * Run buildUpdateRunFromCollection(DataRuntime runtime, int batch, String dest, Collection list, ConfigStore configs, LinkedHashMap columns) * LinkedHashMap confirmUpdateColumns(DataRuntime runtime, String dest, DataRow row, ConfigStore configs, List columns) * LinkedHashMap confirmUpdateColumns(DataRuntime runtime, String dest, Object obj, ConfigStore configs, List columns) * [命令执行] * long update(DataRuntime runtime, String random, String dest, Object data, ConfigStore configs, Run run) ******************************************************************************************************************/ /** * UPDATE [调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param dest 表 如果不提供表名则根据data解析, 表名可以事实前缀<数据源名>表示切换数据源 * @param data 数据 * @param configs 条件 * @param columns 需要插入或更新的列,如果不指定则根据data或configs获取注意会受到ConfigTable中是否插入更新空值的几个配置项影响 * 列可以加前缀
* +:表示必须更新
* -:表示必须不更新
* ?:根据是否有值
* * 如果没有提供columns, 长度为0也算没有提供
* 则解析obj(遍历所有的属性工Key)获取insert列
* * 如果提供了columns则根据columns获取insert列
* * 但是columns中出现了添加前缀列, 则解析完columns后, 继续解析obj
* * 以上执行完后, 如果开启了ConfigTable.IS_AUTO_CHECK_METADATA=true
* 则把执行结果与表结构对比, 删除表中没有的列
* @return 影响行数 */ @Override public long update(DataRuntime runtime, String random, int batch, String dest, Object data, ConfigStore configs, List columns) { return super.update(runtime, random, batch, dest, data, configs, columns); } /** * update [命令合成]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param dest 表 如果不提供表名则根据data解析, 表名可以事实前缀<数据源名>表示切换数据源 * @param obj Entity或DtaRow * @param configs 更新条件 * @param columns 需要插入或更新的列,如果不指定则根据data或configs获取注意会受到ConfigTable中是否插入更新空值的几个配置项影响 * 列可以加前缀
* +:表示必须更新
* -:表示必须不更新
* ?:根据是否有值
* * 如果没有提供columns, 长度为0也算没有提供
* 则解析obj(遍历所有的属性工Key)获取insert列
* * 如果提供了columns则根据columns获取insert列
* * 但是columns中出现了添加前缀列, 则解析完columns后, 继续解析obj
* * 以上执行完后, 如果开启了ConfigTable.IS_AUTO_CHECK_METADATA=true
* 则把执行结果与表结构对比, 删除表中没有的列
* @return Run 最终执行命令 如JDBC环境中的 SQL 与 参数值 */ @Override public Run buildUpdateRun(DataRuntime runtime, int batch, String dest, Object obj, ConfigStore configs, List columns) { return super.buildUpdateRun(runtime, batch, dest, obj, configs, columns); } @Override public Run buildUpdateRunFromEntity(DataRuntime runtime, String dest, Object obj, ConfigStore configs, LinkedHashMap columns) { return super.buildUpdateRunFromEntity(runtime, dest, obj, configs, columns); } @Override public Run buildUpdateRunFromDataRow(DataRuntime runtime, String dest, DataRow row, ConfigStore configs, LinkedHashMap columns) { return super.buildUpdateRunFromDataRow(runtime, dest, row, configs, columns); } @Override public Run buildUpdateRunFromCollection(DataRuntime runtime, int batch, String dest, Collection list, ConfigStore configs, LinkedHashMap columns) { return super.buildUpdateRunFromCollection(runtime, batch, dest, list, configs, columns); } /** * 多表关联更新 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param prepare 一般通过TableBuilder生成 * @param data K-VariableValue 更新值key:需要更新的列 value:通常是关联表的列用VariableValue表示,也可以是常量 * @return 影响行数 */ @Override public Run buildUpdateRun(DataRuntime runtime, RunPrepare prepare, DataRow data, ConfigStore configs, String ... conditions) { return super.buildUpdateRun(runtime, prepare, data, configs, conditions); } @Override public void fillUpdateContent(DataRuntime runtime, TableRun run, StringBuilder builder, DataRow data, ConfigStore configs) { TablePrepare prepare = (TablePrepare)run.getPrepare(); builder.append("UPDATE "); name(runtime, builder, prepare.getTable()); String alias = prepare.getAlias(); if(BasicUtil.isNotEmpty(alias)) { builder.append(tableAliasGuidd()); delimiter(builder, alias); } builder.append(BR); List joins = prepare.getJoins(); if(null != joins) { for (RunPrepare join:joins) { fillJoinTableContent(runtime, builder, run, join); } } String master = alias; if(BasicUtil.isEmpty(master)) { master = prepare.getTableName(); } builder.append("SET").append(BR); List keys = data.keys(); boolean first = true; for(String key:keys) { if(!first) { builder.append(", "); } first = false; if(!key.contains(".")) { builder.append(master).append("."); } builder.append(key).append(" = "); Object value = data.get(key); if(value instanceof VariableValue) { VariableValue var = (VariableValue)value; delimiter(builder, var.value()); }else{ builder.append("?"); RunValue rv = new RunValue(); rv.setValue(value); run.addValue(rv); } } run.appendCondition(builder, this, true, true); } /** * update [命令合成-子流程]
* 确认需要更新的列 * @param row DataRow * @param configs 更新条件 * @param columns 需要插入或更新的列,如果不指定则根据data或configs获取注意会受到ConfigTable中是否插入更新空值的几个配置项影响 * 列可以加前缀
* +:表示必须更新
* -:表示必须不更新
* ?:根据是否有值
* * 如果没有提供columns, 长度为0也算没有提供
* 则解析obj(遍历所有的属性工Key)获取insert列
* * 如果提供了columns则根据columns获取insert列
* * 但是columns中出现了添加前缀列, 则解析完columns后, 继续解析obj
* * 以上执行完后, 如果开启了ConfigTable.IS_AUTO_CHECK_METADATA=true
* 则把执行结果与表结构对比, 删除表中没有的列
* @return List */ @Override public LinkedHashMap confirmUpdateColumns(DataRuntime runtime, String dest, DataRow row, ConfigStore configs, List columns) { return super.confirmUpdateColumns(runtime, dest, row, configs, columns); } @Override public LinkedHashMap confirmUpdateColumns(DataRuntime runtime, String dest, Object obj, ConfigStore configs, List columns) { return super.confirmUpdateColumns(runtime, dest, obj, configs, columns); } /** * update [命令执行]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param dest 表 如果不提供表名则根据data解析, 表名可以事实前缀<数据源名>表示切换数据源 * @param data 数据 * @param run 最终待执行的命令和参数(如JDBC环境中的SQL) * @return 影响行数 */ @Override public long update(DataRuntime runtime, String random, String dest, Object data, ConfigStore configs, Run run) { return super.update(runtime, random, dest, data, configs, run); } /** * save [调用入口]
*
* 根据是否有主键值确认insert | update
* 执行完成后会补齐自增主键值 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param dest 表 如果不提供表名则根据data解析, 表名可以事实前缀<数据源名>表示切换数据源 * @param data 数据 * @param configs 更新条件 * @param columns 需要插入或更新的列,如果不指定则根据data或configs获取注意会受到ConfigTable中是否插入更新空值的几个配置项影响 * 列可以加前缀
* +:表示必须更新
* -:表示必须不更新
* ?:根据是否有值
* * 如果没有提供columns, 长度为0也算没有提供
* 则解析obj(遍历所有的属性工Key)获取insert列
* * 如果提供了columns则根据columns获取insert列
* * 但是columns中出现了添加前缀列, 则解析完columns后, 继续解析obj
* * 以上执行完后, 如果开启了ConfigTable.IS_AUTO_CHECK_METADATA=true
* 则把执行结果与表结构对比, 删除表中没有的列
* @return 影响行数 */ @Override public long save(DataRuntime runtime, String random, String dest, Object data, ConfigStore configs, List columns) { return super.save(runtime, random, dest, data, configs, columns); } @Override protected long saveCollection(DataRuntime runtime, String random, Table dest, Collection data, ConfigStore configs, List columns) { return super.saveCollection(runtime, random, dest, data, configs, columns); } @Override protected long saveObject(DataRuntime runtime, String random, Table dest, Object data, ConfigStore configs, List columns) { return super.saveObject(runtime, random, dest, data, configs, columns); } @Override protected Boolean checkOverride(Object obj, ConfigStore configs) { return super.checkOverride(obj, configs); } @Override protected Boolean checkOverrideSync(Object obj, ConfigStore configs) { return super.checkOverrideSync(obj, configs); } @Override protected Map checkPv(Object obj) { return super.checkPv(obj); } /** * 是否是可以接收数组类型的值 * @param run 最终待执行的命令和参数(如JDBC环境中的SQL) * @param key key * @return boolean */ @Override protected boolean isMultipleValue(DataRuntime runtime, TableRun run, String key) { return super.isMultipleValue(runtime, run, key); } @Override protected boolean isMultipleValue(Column column) { return super.isMultipleValue(column); } /** * 过滤掉表结构中不存在的列 * @param table 表 * @param columns columns * @return List */ @Override public LinkedHashMap checkMetadata(DataRuntime runtime, Table table, ConfigStore configs, LinkedHashMap columns) { return super.checkMetadata(runtime, table, configs, columns); } /* ***************************************************************************************************************** * QUERY * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * DataSet querys(DataRuntime runtime, String random, RunPrepare prepare, ConfigStore configs, String ... conditions) * DataSet querys(DataRuntime runtime, String random, Procedure procedure, PageNavi navi) * EntitySet selects(DataRuntime runtime, String random, RunPrepare prepare, Class clazz, ConfigStore configs, String... conditions) * List> maps(DataRuntime runtime, String random, RunPrepare prepare, ConfigStore configs, String ... conditions) * [命令合成] * Run buildQueryRun(DataRuntime runtime, RunPrepare prepare, ConfigStore configs, String ... conditions) * List buildQuerySequence(DataRuntime runtime, boolean next, String ... names) * Run fillQueryContent(DataRuntime runtime, Run run) * String mergeFinalQuery(DataRuntime runtime, Run run) * RunValue createConditionLike(DataRuntime runtime, StringBuilder builder, Compare compare, Object value, boolean placeholder, boolean unicode) * Object createConditionFindInSet(DataRuntime runtime, StringBuilder builder, String column, Compare compare, Object value, boolean placeholder, boolean unicode) * StringBuilder createConditionIn(DataRuntime runtime, StringBuilder builder, Compare compare, Object value, boolean placeholder, boolean unicode) * [命令执行] * DataSet select(DataRuntime runtime, String random, boolean system, String table, ConfigStore configs, Run run) * List> maps(DataRuntime runtime, String random, ConfigStore configs, Run run) * Map map(DataRuntime runtime, String random, ConfigStore configs, Run run) * DataRow sequence(DataRuntime runtime, String random, boolean next, String ... names) * List> process(DataRuntime runtime, List> list) ******************************************************************************************************************/ /** * query [调用入口]
*
* 返回DataSet中包含元数据信息,如果性能有要求换成maps * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param prepare 构建最终执行命令的全部参数,包含表(或视图|函数|自定义SQL)查询条件 排序 分页等 * @param configs 过滤条件及相关配置 * @param conditions 查询条件 支持k:v k:v::type 以及原生sql形式(包含ORDER、GROUP、HAVING)默认忽略空值条件 * @return DataSet */ @Override public DataSet querys(DataRuntime runtime, String random, RunPrepare prepare, ConfigStore configs, String ... conditions) { return super.querys(runtime, random, prepare, configs, conditions); } /** * query procedure [调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param procedure 存储过程 * @param navi 分页 * @return DataSet */ @Override public DataSet querys(DataRuntime runtime, String random, Procedure procedure, PageNavi navi) { return super.querys(runtime, random, procedure, navi); } /** * query [调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param clazz 类 * @param prepare 构建最终执行命令的全部参数,包含表(或视图|函数|自定义SQL)查询条件 排序 分页等 * @param configs 过滤条件及相关配置 * @param conditions 查询条件 支持k:v k:v::type 以及原生sql形式(包含ORDER、GROUP、HAVING)默认忽略空值条件 * @return EntitySet * @param Entity */ @Override public EntitySet selects(DataRuntime runtime, String random, RunPrepare prepare, Class clazz, ConfigStore configs, String ... conditions) { return super.selects(runtime, random, prepare, clazz, configs, conditions); } /** * select [命令执行-子流程]
* DataRow转换成Entity * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param clazz entity class * @param table table * @param run 最终待执行的命令和参数(如JDBC环境中的SQL) * @return EntitySet * @param entity.class * */ @Override protected EntitySet select(DataRuntime runtime, String random, Class clazz, Table table, ConfigStore configs, Run run) { return super.select(runtime, random, clazz, table, configs, run); } /** * query [调用入口]
*
* 对性能有要求的场景调用,返回java原生map集合, 结果中不包含元数据信息 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param prepare 构建最终执行命令的全部参数,包含表(或视图|函数|自定义SQL)查询条件 排序 分页等 * @param configs 过滤条件及相关配置 * @param conditions 查询条件 支持k:v k:v::type 以及原生sql形式(包含ORDER、GROUP、HAVING)默认忽略空值条件 * @return maps 返回map集合 */ @Override public List> maps(DataRuntime runtime, String random, RunPrepare prepare, ConfigStore configs, String ... conditions) { return super.maps(runtime, random, prepare, configs, conditions); } /** * select[命令合成]
最终可执行命令
* 创建查询SQL * @param prepare 构建最终执行命令的全部参数,包含表(或视图|函数|自定义SQL)查询条件 排序 分页等 * @param configs 过滤条件及相关配置 * @param conditions 查询条件 支持k:v k:v::type 以及原生sql形式(包含ORDER、GROUP、HAVING)默认忽略空值条件 * @return Run 最终执行命令 如JDBC环境中的 SQL 与 参数值 */ @Override public Run buildQueryRun(DataRuntime runtime, RunPrepare prepare, ConfigStore configs, String ... conditions) { return super.buildQueryRun(runtime, prepare, configs, conditions); } /** * 查询序列cur 或 next value * @param next 是否生成返回下一个序列 false:cur true:next * @param names 序列名 * @return String */ @Override public List buildQuerySequence(DataRuntime runtime, boolean next, String ... names) { return super.buildQuerySequence(runtime, next, names); } /** * select[命令合成-子流程]
* 构造查询主体 * @param run 最终待执行的命令和参数(如JDBC环境中的SQL) */ @Override public Run fillQueryContent(DataRuntime runtime, Run run) { return super.fillQueryContent(runtime, run); } @Override protected Run fillQueryContent(DataRuntime runtime, XMLRun run) { return super.fillQueryContent(runtime, run); } @Override protected Run fillQueryContent(DataRuntime runtime, TextRun run) { return super.fillQueryContent(runtime, run); } @Override protected Run fillQueryContent(DataRuntime runtime, TableRun run) { return super.fillQueryContent(runtime, run); } /** * select[命令合成-子流程]
* 合成最终 select 命令 包含分页 排序 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param run 最终待执行的命令和参数(如JDBC环境中的SQL) * @return String */ @Override public String mergeFinalQuery(DataRuntime runtime, Run run) { return super.pageLimitOffset(runtime, run); } /** * select[命令合成-子流程]
* 构造 LIKE 查询条件 * 如果不需要占位符 返回null 否则原样返回value * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param compare 比较方式 默认 equal 多个值默认 in * @param value value * @return value 有占位符时返回占位值,没有占位符返回null */ @Override public RunValue createConditionLike(DataRuntime runtime, StringBuilder builder, Compare compare, Object value, boolean placeholder, boolean unicode) { return super.createConditionLike(runtime, builder, compare, value, placeholder, unicode); } /** * select[命令合成-子流程]
* 构造 FIND_IN_SET 查询条件 * 如果不需要占位符 返回null 否则原样返回value * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param column 列 * @param compare 比较方式 默认 equal 多个值默认 in * @param value value * @return value */ @Override public Object createConditionFindInSet(DataRuntime runtime, StringBuilder builder, String column, Compare compare, Object value, boolean placeholder, boolean unicode) throws NotSupportException { List values = BeanUtil.object2list(value); if(values.size() > 1) { builder.append("("); } boolean first = true; String join = " OR "; if(compare == Compare.FIND_IN_SET_AND) { join = " AND "; } for(Object v:values) { if(!first) { builder.append(join); } if(placeholder) { builder.append("FIND_IN_SET(?, ").append(column).append(")"); }else{ builder.append("FIND_IN_SET('").append(v).append("', ").append(column).append(")"); } first = false; } if(values.size() > 1) { builder.append(")"); } return value; } /** * select[命令合成-子流程]
* 构造 JSON_CONTAINS 查询条件 * 如果不需要占位符 返回null 否则原样返回value * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param column 列 * @param compare 比较方式 默认 equal 多个值默认 in * @param value value * @return value */ @Override public Object createConditionJsonContains(DataRuntime runtime, StringBuilder builder, String column, Compare compare, Object value, boolean placeholder, boolean unicode) { //json_contains(JSON_COLUMN,'"VIP"','$.name') List values = BeanUtil.object2list(value); List returns = new ArrayList<>(); if(values.size() > 1) { builder.append("("); } boolean first = true; String join = " OR "; if(compare == Compare.JSON_CONTAINS_AND) { join = " AND "; } String key = null; if(column.contains(">")) { String[] ks = column.split(">"); column = ks[0]; key = ks[1]; } for(Object v:values) { if(!first) { builder.append(join); } if(BasicUtil.isNumber(v)) { v = v.toString(); }else{ String str = v.toString(); if(str.startsWith("${") && str.endsWith("}")) { str = str.substring(2, str.length()-1); }else if(!str.startsWith("\"")) { str = "\""+str+"\""; } v = str; } builder.append("JSON_CONTAINS(").append(column).append(", "); if(placeholder) { builder.append("?"); } else { builder.append(v); } if(BasicUtil.isNotEmpty(key)) { builder.append(",'").append(key).append("'"); } builder.append(")"); returns.add(v); first = false; } if(values.size() > 1) { builder.append(")"); } return returns; } /** * select[命令合成-子流程]
* 构造 JSON_CONTAINS 查询条件 * 如果不需要占位符 返回null 否则原样返回value * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param column 列 * @param compare 比较方式 默认 equal 多个值默认 in * @param value value * @return value */ @Override public Object createConditionJsonContainsPath(DataRuntime runtime, StringBuilder builder, String column, Compare compare, Object value, boolean placeholder, boolean unicode) { //JSON_CONTAINS_PATH(JSON_COLUMN, 'all', '$.A', '$.D') String scope = "one"; if(compare.getCode() == 76) { scope = "all"; } Collection values = new ArrayList<>(); if(value instanceof Collection) { values = (Collection) value; }else{ values.add(value); } builder.append("JSON_CONTAINS_PATH(").append(column).append(", '").append(scope).append("'"); for(Object v:values) { builder.append(", "); if(placeholder) { builder.append("?"); }else{ builder.append("'").append(v).append("'"); } } builder.append(")"); return value; } /** * select[命令合成-子流程]
* 构造 JSON_SEARCH 查询条件(默认 IS NOT NULL) * 如果不需要占位符 返回null 否则原样返回value * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param column 列 * @param compare 比较方式 默认 equal 多个值默认 in * @param value value * @return value */ @Override public Object createConditionJsonSearch(DataRuntime runtime, StringBuilder builder, String column, Compare compare, Object value, boolean placeholder, boolean unicode) throws NotSupportException { //JSON_SEARCH(JSON_COLUMN, 'one', 'abc') IS NOT NULL String scope = "one"; if(compare.getCode() == 78) { scope = "all"; } Collection values = new ArrayList<>(); if(value instanceof Collection) { values = (Collection) value; }else{ values.add(value); } builder.append("JSON_SEARCH(").append(column).append(", '").append(scope).append("'"); for(Object v:values) { builder.append(", "); if(placeholder) { builder.append("?"); }else{ builder.append("'").append(v).append("'"); } } builder.append(") IS NOT NULL"); return value; } /** * select[命令合成-子流程]
* 构造(NOT) IN 查询条件 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param compare 比较方式 默认 equal 多个值默认 in * @param value value * @return builder */ @Override public StringBuilder createConditionIn(DataRuntime runtime, StringBuilder builder, Compare compare, Object value, boolean placeholder, boolean unicode) { return super.createConditionIn(runtime, builder, compare, value, placeholder, unicode); } /** * select [命令执行]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param system 系统表不检测列属性 * @param table 表 * @param run 最终待执行的命令和参数(如JDBC环境中的SQL) * @return DataSet */ @Override public DataSet select(DataRuntime runtime, String random, boolean system, Table table, ConfigStore configs, Run run) { return super.select(runtime, random, system, table, configs, run); } /** * select [命令执行]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param run 最终待执行的命令和参数(如JDBC环境中的SQL) * @return maps */ @Override public List> maps(DataRuntime runtime, String random, ConfigStore configs, Run run) { return super.maps(runtime, random, configs, run); } /** * select [命令执行]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param run 最终待执行的命令和参数(如JDBC环境中的SQL) * @return map */ @Override public Map map(DataRuntime runtime, String random, ConfigStore configs, Run run) { return super.map(runtime, random, configs, run); } /** * select [命令执行]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param next 是否查下一个序列值 * @param names 存储过程名称s * @return DataRow 保存序列查询结果 以存储过程name作为key */ @Override public DataRow sequence(DataRuntime runtime, String random, boolean next, String ... names) { return super.sequence(runtime, random, next, names); } /** * select [命令执行-子流程]
* JDBC执行完成后的结果处理 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param list JDBC执行返回的结果集 * @return maps */ @Override public List> process(DataRuntime runtime, List> list) { return super.process(runtime, list); } /* ***************************************************************************************************************** * COUNT * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * long count(DataRuntime runtime, String random, RunPrepare prepare, ConfigStore configs, String ... conditions) * [命令合成] * String mergeFinalTotal(DataRuntime runtime, Run run) * [命令执行] * long count(DataRuntime runtime, String random, Run run) ******************************************************************************************************************/ /** * count [调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param prepare 构建最终执行命令的全部参数,包含表(或视图|函数|自定义SQL)查询条件 排序 分页等 * @param configs 过滤条件及相关配置 * @param conditions 查询条件 支持k:v k:v::type 以及原生sql形式(包含ORDER、GROUP、HAVING)默认忽略空值条件 * @return long */ @Override public long count(DataRuntime runtime, String random, RunPrepare prepare, ConfigStore configs, String ... conditions) { return super.count(runtime, random, prepare, configs, conditions); } /** * count [命令合成]
* 合成最终 select count 命令 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param run 最终待执行的命令和参数(如JDBC环境中的SQL) * @return String */ @Override public String mergeFinalTotal(DataRuntime runtime, Run run) { return super.mergeFinalTotal(runtime, run); } /** * count [命令执行]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param run 最终待执行的命令和参数(如JDBC环境中的SQL) * @return long */ @Override public long count(DataRuntime runtime, String random, Run run) { return super.count(runtime, random, run); } /* ***************************************************************************************************************** * EXISTS * ----------------------------------------------------------------------------------------------------------------- * boolean exists(DataRuntime runtime, String random, RunPrepare prepare, ConfigStore configs, String ... conditions) * String mergeFinalExists(DataRuntime runtime, Run run) ******************************************************************************************************************/ /** * exists [调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param prepare 构建最终执行命令的全部参数,包含表(或视图|函数|自定义SQL)查询条件 排序 分页等 * @param configs 查询条件及相关设置 * @param conditions 查询条件 支持k:v k:v::type 以及原生sql形式(包含ORDER、GROUP、HAVING)默认忽略空值条件 * @return boolean */ @Override public boolean exists(DataRuntime runtime, String random, RunPrepare prepare, ConfigStore configs, String ... conditions) { return super.exists(runtime, random, prepare, configs, conditions); } @Override public String mergeFinalExists(DataRuntime runtime, Run run) { return super.mergeFinalExists(runtime, run); } /* ***************************************************************************************************************** * EXECUTE * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * long execute(DataRuntime runtime, String random, RunPrepare prepare, ConfigStore configs, String ... conditions) * long execute(DataRuntime runtime, String random, int batch, ConfigStore configs, RunPrepare prepare, Collection values) * boolean execute(DataRuntime runtime, String random, Procedure procedure) * [命令合成] * Run buildExecuteRun(DataRuntime runtime, RunPrepare prepare, ConfigStore configs, String ... conditions) * void fillExecuteContent(DataRuntime runtime, Run run) * [命令执行] * long execute(DataRuntime runtime, String random, ConfigStore configs, Run run) ******************************************************************************************************************/ /** * execute [调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param prepare 构建最终执行命令的全部参数,包含表(或视图|函数|自定义SQL)查询条件 排序 分页等 * @param configs 查询条件及相关设置 * @param conditions 查询条件 支持k:v k:v::type 以及原生sql形式(包含ORDER、GROUP、HAVING)默认忽略空值条件 * @return 影响行数 */ @Override public long execute(DataRuntime runtime, String random, RunPrepare prepare, ConfigStore configs, String ... conditions) { return super.execute(runtime, random, prepare, configs, conditions); } @Override public long execute(DataRuntime runtime, String random, int batch, ConfigStore configs, RunPrepare prepare, Collection values) { return super.execute(runtime, random, batch, configs, prepare, values); } /** * procedure [命令执行]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param procedure 存储过程 * @param random random * @return 影响行数 */ @Override public boolean execute(DataRuntime runtime, String random, Procedure procedure) { return super.execute(runtime, random, procedure); } /** * execute [命令合成]
* 创建执行SQL * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param prepare 构建最终执行命令的全部参数,包含表(或视图|函数|自定义SQL)查询条件 排序 分页等 * @param configs 查询条件及相关设置 * @param conditions 查询条件 支持k:v k:v::type 以及原生sql形式(包含ORDER、GROUP、HAVING)默认忽略空值条件 * @return Run 最终执行命令 如JDBC环境中的 SQL 与 参数值 */ @Override public Run buildExecuteRun(DataRuntime runtime, RunPrepare prepare, ConfigStore configs, String ... conditions) { return super.buildExecuteRun(runtime, prepare, configs, conditions); } @Override protected void fillExecuteContent(DataRuntime runtime, XMLRun run) { super.fillExecuteContent(runtime, run); } @Override protected void fillExecuteContent(DataRuntime runtime, TextRun run) { super.fillExecuteContent(runtime, run); } @Override protected void fillExecuteContent(DataRuntime runtime, TableRun run) { super.fillExecuteContent(runtime, run); } /** * execute [命令合成-子流程]
* 填充 execute 命令内容 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param run 最终待执行的命令和参数(如JDBC环境中的SQL) */ @Override public void fillExecuteContent(DataRuntime runtime, Run run) { super.fillExecuteContent(runtime, run); } /** * execute [命令执行]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param run 最终待执行的命令和参数(如JDBC环境中的SQL) * @return 影响行数 */ @Override public long execute(DataRuntime runtime, String random, ConfigStore configs, Run run) { return super.execute(runtime, random, configs, run); } /* ***************************************************************************************************************** * DELETE * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * long deletes(DataRuntime runtime, String random, int batch, String table, ConfigStore configs, String column, Collection values) * long delete(DataRuntime runtime, String random, String table, ConfigStore configs, Object obj, String... columns) * long delete(DataRuntime runtime, String random, String table, ConfigStore configs, String... conditions) * long truncate(DataRuntime runtime, String random, String table) * [命令合成] * List buildDeleteRun(DataRuntime runtime, String table, ConfigStore configs, Object obj, String ... columns) * List buildDeleteRun(DataRuntime runtime, int batch, String table, ConfigStore configs, String column, Object values) * List buildTruncateRun(DataRuntime runtime, String table) * List buildDeleteRunFromTable(DataRuntime runtime, int batch, String table, ConfigStore configs,String column, Object values) * List buildDeleteRunFromEntity(DataRuntime runtime, String table, ConfigStore configs, Object obj, String ... columns) * void fillDeleteRunContent(DataRuntime runtime, Run run) * [命令执行] * long delete(DataRuntime runtime, String random, ConfigStore configs, Run run) ******************************************************************************************************************/ /** * delete [调用入口]
*
* 合成 where column in (values) * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param table 表 如果不提供表名则根据data解析, 表名可以事实前缀<数据源名>表示切换数据源 * @param values 列对应的值 * @return 影响行数 * @param T */ @Override public long deletes(DataRuntime runtime, String random, int batch, String table, ConfigStore configs, String key, Collection values) { return super.deletes(runtime, random, batch, table, configs, key, values); } /** * delete [调用入口]
*
* 合成 where k1 = v1 and k2 = v2 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param obj entity或DataRow * @param columns 删除条件的列或属性,根据columns取obj值并合成删除条件 * @return 影响行数 */ @Override public long delete(DataRuntime runtime, String random, String dest, ConfigStore configs, Object obj, String... columns) { return super.delete(runtime, random, dest, configs, obj, columns); } /** * delete [调用入口]
*
* 根据configs和conditions过滤条件 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param table 表 * @param configs 查询条件及相关设置 * @param conditions 查询条件 支持k:v k:v::type 以及原生sql形式(包含ORDER、GROUP、HAVING)默认忽略空值条件 * @return 影响行数 */ @Override public long delete(DataRuntime runtime, String random, String table, ConfigStore configs, String... conditions) { return super.delete(runtime, random, table, configs, conditions); } /** * truncate [调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param table 表 * @return 1表示成功执行 */ @Override public long truncate(DataRuntime runtime, String random, Table table) { return super.truncate(runtime, random, table); } /** * delete[命令合成]
* 合成 where k1 = v1 and k2 = v2 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param dest 表 如果不提供表名则根据data解析, 表名可以事实前缀<数据源名>表示切换数据源 * @param obj entity或DataRow * @param columns 删除条件的列或属性,根据columns取obj值并合成删除条件 * @return Run 最终执行命令 如JDBC环境中的 SQL 与 参数值 */ @Override public List buildDeleteRun(DataRuntime runtime, Table dest, ConfigStore configs, Object obj, String ... columns) { return super.buildDeleteRun(runtime, dest, configs, obj, columns); } /** * delete[命令合成]
* 合成 where column in (values) * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param table 表 如果不提供表名则根据data解析, 表名可以事实前缀<数据源名>表示切换数据源 * @param key 根据属性解析出列 * @param values values * @return Run 最终执行命令 如JDBC环境中的 SQL 与 参数值 */ @Override public List buildDeleteRun(DataRuntime runtime, int batch, String table, ConfigStore configs, String key, Object values) { return super.buildDeleteRun(runtime, batch, table, configs, key, values); } @Override public List buildTruncateRun(DataRuntime runtime, String table) { return super.buildTruncateRun(runtime, table); } /** * delete[命令合成-子流程]
* 合成 where column in (values) * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param table 表 如果不提供表名则根据data解析, 表名可以事实前缀<数据源名>表示切换数据源 * @param column 列 * @param values values * @return Run 最终执行命令 如JDBC环境中的 SQL 与 参数值 */ @Override public List buildDeleteRunFromTable(DataRuntime runtime, int batch, Table table, ConfigStore configs, String column, Object values) { return super.buildDeleteRunFromTable(runtime, batch, table, configs, column, values); } /** * delete[命令合成-子流程]
* 合成 where k1 = v1 and k2 = v2 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param table 表 如果不提供表名则根据data解析, 表名可以事实前缀<数据源名>表示切换数据源 如果为空 可以根据obj解析 * @param obj entity或DataRow * @param columns 删除条件的列或属性,根据columns取obj值并合成删除条件 * @return Run 最终执行命令 如JDBC环境中的 SQL 与 参数值 */ @Override public List buildDeleteRunFromEntity(DataRuntime runtime, Table table, ConfigStore configs, Object obj, String... columns) { return super.buildDeleteRunFromEntity(runtime, table, configs, obj, columns); } /** * delete[命令合成-子流程]
* 构造查询主体 拼接where group等(不含分页 ORDER) * @param run 最终待执行的命令和参数(如JDBC环境中的SQL) */ @Override public void fillDeleteRunContent(DataRuntime runtime, Run run) { super.fillDeleteRunContent(runtime, run); } /** * delete[命令执行]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param configs 查询条件及相关设置 * @param run 最终待执行的命令和参数(如JDBC环境中的SQL) * @return 影响行数 */ @Override public long delete(DataRuntime runtime, String random, ConfigStore configs, Run run) { return super.delete(runtime, random, configs, run); } /* ***************************************************************************************************************** * * metadata * * ================================================================================================================= * database : 数据库(catalog, schema) * table : 表 * master table : 主表 * partition table : 分区表 * column : 列 * tag : 标签 * primary key : 主键 * foreign key : 外键 * index : 索引 * constraint : 约束 * trigger : 触发器 * procedure : 存储过程 * function : 函数 ******************************************************************************************************************/ /* ***************************************************************************************************************** * database * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * LinkedHashMap databases(DataRuntime runtime, String random, String name) * List databases(DataRuntime runtime, String random, boolean greedy, String name) * Database database(DataRuntime runtime, String random, String name) * [命令合成] * List buildQueryDatabasesRun(DataRuntime runtime, boolean greedy, String name) * [结果集封装]
* LinkedHashMap databases(DataRuntime runtime, int index, boolean create, LinkedHashMap databases, Catalog catalog, Schema schema, DataSet set) * List databases(DataRuntime runtime, int index, boolean create, List databases, Catalog catalog, Schema schema, DataSet set) * Database database(DataRuntime runtime, boolean create, Database dataase, DataSet set) * Database database(DataRuntime runtime, boolean create, Database dataase) ******************************************************************************************************************/ /** * database[调用入口]
* 当前数据库 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @return Database */ @Override public Database database(DataRuntime runtime, String random) { Schema schema = schema(runtime, random); if(null != schema) { return new Database(schema.getName()); } return super.database(runtime, random); } /** * database[调用入口]
* 当前数据源 数据库描述(产品名称+版本号) * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @return String */ public String product(DataRuntime runtime, String random) { return super.product(runtime, random); } /** * database[调用入口]
* 当前数据源 数据库类型 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @return String */ public String version(DataRuntime runtime, String random) { return super.version(runtime, random); } /** * database[调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param greedy 贪婪模式 true:查询权限范围内尽可能多的数据 false:只查当前catalog/schema/database范围内数据 * @param query 查询条件 根据metadata属性 * @return LinkedHashMap */ @Override public List databases(DataRuntime runtime, String random, boolean greedy, Database query) { return super.databases(runtime, random, greedy, query); } /** * database[调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param query 查询条件 根据metadata属性 * @return LinkedHashMap */ @Override public LinkedHashMap databases(DataRuntime runtime, String random, Database query) { return super.databases(runtime, random, query); } /** * database[命令合成]
* 查询全部数据库 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param query 查询条件 根据metadata属性 * @param greedy 贪婪模式 true:查询权限范围内尽可能多的数据 false:只查当前catalog/schema/database范围内数据 * @return runs * @throws Exception 异常 */ @Override public List buildQueryDatabasesRun(DataRuntime runtime, boolean greedy, Database query) throws Exception { String name = query.getName(); List runs = new ArrayList<>(); Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); builder.append("SHOW DATABASES"); if(BasicUtil.isNotEmpty(name)) { builder.append(" LIKE '").append(name).append("'"); } return runs; } /** * database[结果集封装]
* database 属性与结果集对应关系 * @return MetadataFieldRefer */ @Override public MetadataFieldRefer initDatabaseFieldRefer() { MetadataFieldRefer refer = new MetadataFieldRefer(Database.class); refer.map(Database.FIELD_NAME, "DATABASE"); return refer; } /** * database[结果集封装]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条SQL 对照 buildQueryDatabaseRun 返回顺序 * @param create 上一步没有查到的, 这一步是否需要新创建 * @param previous 上一步查询结果 * @param set 查询结果集 * @return LinkedHashMap * @throws Exception Exception */ @Override public LinkedHashMap databases(DataRuntime runtime, int index, boolean create, LinkedHashMap previous, Database query, DataSet set) throws Exception { return super.databases(runtime, index, create, previous, query, set); } @Override public List databases(DataRuntime runtime, int index, boolean create, List previous, Database query, DataSet set) throws Exception { return super.databases(runtime, index, create, previous, query, set); } /** * database[结果集封装]
* 当前database 根据查询结果集 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条SQL 对照 buildQueryDatabaseRun 返回顺序 * @param create 上一步没有查到的, 这一步是否需要新创建 * @param meta 上一步查询结果 * @param set 查询结果集 * @return database * @throws Exception 异 */ @Override public Database database(DataRuntime runtime, int index, boolean create, Database meta, DataSet set) throws Exception { if(null == meta) { for (DataRow row : set) { meta = new Database(); meta.setName(row.getString("DATABASE")); return meta; } } return meta; } /** * database[结果集封装]
* 当前database 根据驱动内置接口补充 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param create 上一步没有查到的, 这一步是否需要新创建 * @param meta 上一步查询结果 * @return database * @throws Exception 异常 */ @Override public Database database(DataRuntime runtime, boolean create, Database meta) throws Exception { return super.database(runtime, create, meta); } /** * database[结果集封装]
* 根据查询结果集构造 product * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param create 上一步没有查到的, 这一步是否需要新创建 * @param product 上一步查询结果 * @param set 查询结果集 * @return product * @throws Exception 异常 */ @Override public String product(DataRuntime runtime, int index, boolean create, String product, DataSet set) { return super.product(runtime, index, create, product, set); } /** * database[结果集封装]
* 根据JDBC内置接口 product * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param create 上一步没有查到的, 这一步是否需要新创建 * @param product 上一步查询结果 * @return product * @throws Exception 异常 */ @Override public String product(DataRuntime runtime, boolean create, String product) { return super.product(runtime, create, product); } /** * database[结果集封装]
* 根据查询结果集构造 version * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param create 上一步没有查到的, 这一步是否需要新创建 * @param version 上一步查询结果 * @param set 查询结果集 * @return version * @throws Exception 异常 */ @Override public String version(DataRuntime runtime, int index, boolean create, String version, DataSet set) { return super.version(runtime, index, create, version, set); } /** * database[结果集封装]
* 根据JDBC内置接口 version * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param create 上一步没有查到的, 这一步是否需要新创建 * @param version 上一步查询结果 * @return version * @throws Exception 异常 */ @Override public String version(DataRuntime runtime, boolean create, String version) { return super.version(runtime, create, version); } /** * schema[结果集封装]
* 根据查询结果封装 schema 对象,只封装catalog,schema,name等基础属性 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 上一步封装结果 * @param query 查询条件 根据metadata属性 * @param row 查询结果集 * @return Database */ @Override public T init(DataRuntime runtime, int index, T meta, Database query, DataRow row) { return super.init(runtime, index, meta, query, row); } /** * database[结果集封装]
* 根据查询结果封装 database 对象,更多属性 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 上一步封装结果 * @param row 查询结果集 * @return Table */ @Override public T detail(DataRuntime runtime, int index, T meta, Database query, DataRow row) { return super.detail(runtime, index, meta, query, row); } /* ***************************************************************************************************************** * catalog * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * LinkedHashMap catalogs(DataRuntime runtime, String random, String name) * List catalogs(DataRuntime runtime, String random, boolean greedy, String name) * [命令合成] * List buildQueryCatalogsRun(DataRuntime runtime, boolean greedy, String name) * [结果集封装]
* List catalogs(DataRuntime runtime, int index, boolean create, List catalogs, DataSet set) * LinkedHashMap catalogs(DataRuntime runtime, int index, boolean create, LinkedHashMap catalogs, DataSet set) * List catalogs(DataRuntime runtime, boolean create, List catalogs, DataSet set) * LinkedHashMap catalogs(DataRuntime runtime, boolean create, LinkedHashMap catalogs, DataSet set) * Catalog catalog(DataRuntime runtime, int index, boolean create, DataSet set) ******************************************************************************************************************/ /** * catalog[调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param query 查询条件 根据metadata属性 * @return LinkedHashMap */ @Override public LinkedHashMap catalogs(DataRuntime runtime, String random, Catalog query) { return super.catalogs(runtime, random, query); } /** * catalog[调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param query 查询条件 根据metadata属性 * @return LinkedHashMap */ @Override public List catalogs(DataRuntime runtime, String random, boolean greedy, Catalog query) { return super.catalogs(runtime, random, greedy, query); } /** * catalog[命令合成]
* 查询全部数据库 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param query 查询条件 根据metadata属性 * @param greedy 贪婪模式 true:查询权限范围内尽可能多的数据 false:只查当前catalog/schema/database范围内数据 * @return runs * @throws Exception 异常 */ @Override public List buildQueryCatalogsRun(DataRuntime runtime, boolean greedy, Catalog query) throws Exception { return super.buildQueryCatalogsRun(runtime, greedy, query); } /** * Catalog[结果集封装]
* Catalog 属性与结果集对应关系 * @return MetadataFieldRefer */ @Override public MetadataFieldRefer initCatalogFieldRefer() { return super.initCatalogFieldRefer(); } /** * catalog[结果集封装]
* 根据查询结果集构造 Database * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条SQL 对照 buildQueryDatabaseRun 返回顺序 * @param create 上一步没有查到的, 这一步是否需要新创建 * @param previous 上一步查询结果 * @param set 查询结果集 * @return databases * @throws Exception 异常 */ @Override public LinkedHashMap catalogs(DataRuntime runtime, int index, boolean create, LinkedHashMap previous, Catalog query, DataSet set) throws Exception { return super.catalogs(runtime, index, create, previous, query, set); } /** * catalog[结果集封装]
* 根据查询结果集构造 Database * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条SQL 对照 buildQueryDatabaseRun 返回顺序 * @param create 上一步没有查到的, 这一步是否需要新创建 * @param previous 上一步查询结果 * @param set 查询结果集 * @return databases * @throws Exception 异常 */ @Override public List catalogs(DataRuntime runtime, int index, boolean create, List previous, Catalog query, DataSet set) throws Exception { return super.catalogs(runtime, index, create, previous, query, set); } /** * catalog[结果集封装]
* 根据驱动内置接口补充 catalog * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param create 上一步没有查到的, 这一步是否需要新创建 * @param previous 上一步查询结果 * @return databases * @throws Exception 异常 */ @Override public LinkedHashMap catalogs(DataRuntime runtime, boolean create, LinkedHashMap previous) throws Exception { return super.catalogs(runtime, create, previous); } /** * catalog[结果集封装]
* 根据驱动内置接口补充 catalog * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param create 上一步没有查到的, 这一步是否需要新创建 * @param previous 上一步查询结果 * @return databases * @throws Exception 异常 */ @Override public List catalogs(DataRuntime runtime, boolean create, List previous) throws Exception { return super.catalogs(runtime, create, previous); } /** * catalog[结果集封装]
* 当前catalog 根据查询结果集 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条SQL 对照 buildQueryDatabaseRun 返回顺序 * @param create 上一步没有查到的, 这一步是否需要新创建 * @param meta 上一步查询结果 * @param set 查询结果集 * @return Catalog * @throws Exception 异常 */ @Override public Catalog catalog(DataRuntime runtime, int index, boolean create, Catalog meta, DataSet set) throws Exception { return super.catalog(runtime, index, create, meta, set); } /** * catalog[结果集封装]
* 当前catalog 根据驱动内置接口补充 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param create 上一步没有查到的, 这一步是否需要新创建 * @param meta 上一步查询结果 * @return Catalog * @throws Exception 异常 */ @Override public Catalog catalog(DataRuntime runtime, boolean create, Catalog meta) throws Exception { return super.catalog(runtime, create, meta); } /** * catalog[结果集封装]
* 根据查询结果封装 catalog 对象,只封装catalog,schema,name等基础属性 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 上一步封装结果 * @param query 查询条件 根据metadata属性 * @param row 查询结果集 * @return Catalog */ @Override public T init(DataRuntime runtime, int index, T meta, Catalog query, DataRow row) { return super.init(runtime, index, meta, query, row); } /** * catalog[结果集封装]
* 根据查询结果封装 catalog 对象,更多属性 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 上一步封装结果 * @param row 查询结果集 * @return Table */ @Override public T detail(DataRuntime runtime, int index, T meta, Catalog query, DataRow row) { return super.detail(runtime, index, meta, query, row); } /* ***************************************************************************************************************** * schema * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * LinkedHashMap databases(DataRuntime runtime, String random, String name) * List databases(DataRuntime runtime, String random, boolean greedy, String name) * Database database(DataRuntime runtime, String random, String name) * Database database(DataRuntime runtime, String random) * String String product(DataRuntime runtime, String random); * String String version(DataRuntime runtime, String random); * [命令合成] * List buildQueryDatabasesRun(DataRuntime runtime, boolean greedy, String name) * List buildQueryDatabaseRun(DataRuntime runtime, boolean greedy, String name) * List buildQueryProductRun(DataRuntime runtime, boolean greedy, String name) * List buildQueryVersionRun(DataRuntime runtime, boolean greedy, String name) * [结果集封装]
* LinkedHashMap databases(DataRuntime runtime, int index, boolean create, LinkedHashMap databases, Catalog catalog, Schema schema, DataSet set) * List databases(DataRuntime runtime, int index, boolean create, List databases, Catalog catalog, Schema schema, DataSet set) * Database database(DataRuntime runtime, boolean create, Database dataase, DataSet set) * Database database(DataRuntime runtime, boolean create, Database dataase) * String product(DataRuntime runtime, boolean create, Database product, DataSet set) * String product(DataRuntime runtime, boolean create, String product) * String version(DataRuntime runtime, int index, boolean create, String version, DataSet set) * String version(DataRuntime runtime, boolean create, String version) * Catalog catalog(DataRuntime runtime, boolean create, Catalog catalog, DataSet set) * Catalog catalog(DataRuntime runtime, boolean create, Catalog catalog) * Schema schema(DataRuntime runtime, boolean create, Schema schema, DataSet set) * Schema schema(DataRuntime runtime, boolean create, Schema schema) * Database database(DataRuntime runtime, boolean create, Database dataase) ******************************************************************************************************************/ /** * schema[调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param query 查询条件 根据metadata属性 * @return LinkedHashMap */ @Override public LinkedHashMap schemas(DataRuntime runtime, String random, Schema query) { return super.schemas(runtime, random, query); } /** * schema[调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param query 查询条件 根据metadata属性 * @return LinkedHashMap */ @Override public List schemas(DataRuntime runtime, String random, boolean greedy, Schema query) { return super.schemas(runtime, random, greedy, query); } /** * catalog[命令合成]
* 查询全部数据库 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param query 查询条件 根据metadata属性 * @param greedy 贪婪模式 true:查询权限范围内尽可能多的数据 false:只查当前catalog/schema/database范围内数据 * @return runs * @throws Exception 异常 */ @Override public List buildQuerySchemasRun(DataRuntime runtime, boolean greedy, Schema query) throws Exception { String name = query.getName(); List runs = new ArrayList<>(); Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); builder.append("SHOW SCHEMAS"); if(BasicUtil.isNotEmpty(name)) { builder.append(" LIKE '").append(name).append("'"); } return runs; } /** * Schema[结果集封装]
* Schema 属性与结果集对应关系 * @return MetadataFieldRefer */ @Override public MetadataFieldRefer initSchemaFieldRefer() { MetadataFieldRefer refer = new MetadataFieldRefer(Schema.class); refer.map(Schema.FIELD_NAME, "DATABASE"); return refer; } /** * schema[结果集封装]
* 根据查询结果集构造 Database * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条SQL 对照 buildQueryDatabaseRun 返回顺序 * @param create 上一步没有查到的, 这一步是否需要新创建 * @param previous 上一步查询结果 * @param set 查询结果集 * @return databases * @throws Exception 异常 */ @Override public LinkedHashMap schemas(DataRuntime runtime, int index, boolean create, LinkedHashMap previous, Schema query, DataSet set) throws Exception { return super.schemas(runtime, index, create, previous, query, set); } @Override public List schemas(DataRuntime runtime, int index, boolean create, List previous, Schema query, DataSet set) throws Exception { return super.schemas(runtime, index, create, previous, query, set); } /** * schema[结果集封装]
* 当前schema 根据查询结果集 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条SQL 对照 buildQuerySchemaRun 返回顺序 * @param create 上一步没有查到的, 这一步是否需要新创建 * @param meta 上一步查询结果 * @param set 查询结果集 * @return schema * @throws Exception 异常 */ @Override public Schema schema(DataRuntime runtime, int index, boolean create, Schema meta, DataSet set) throws Exception { return super.schema(runtime, index, create, meta, set); } /** * schema[结果集封装]
* 当前schema 根据驱动内置接口补充 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param create 上一步没有查到的, 这一步是否需要新创建 * @param meta 上一步查询结果 * @return schema * @throws Exception 异常 */ @Override public Schema schema(DataRuntime runtime, boolean create, Schema meta) throws Exception { return super.schema(runtime, create, meta); } /** * schema[结果集封装]
* 根据查询结果封装 schema 对象,只封装catalog,schema,name等基础属性 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 上一步封装结果 * @param query 查询条件 根据metadata属性 * @param row 查询结果集 * @return Schema */ @Override public T init(DataRuntime runtime, int index, T meta, Schema query, DataRow row) { return super.init(runtime, index, meta, query, row); } /** * schema[结果集封装]
* 根据查询结果封装 schema 对象,更多属性 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 上一步封装结果 * @param row 查询结果集 * @return Table */ @Override public T detail(DataRuntime runtime, int index, T meta, Schema query, DataRow row) { return super.detail(runtime, index, meta, query, row); } /* ***************************************************************************************************************** * table * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * List tables(DataRuntime runtime, String random, boolean greedy, Catalog catalog, Schema schema, String pattern, int types, boolean struct) * LinkedHashMap tables(DataRuntime runtime, String random, Catalog catalog, Schema schema, String pattern, String types, boolean struct) * [命令合成] * List buildQueryTablesRun(DataRuntime runtime, boolean greedy, Catalog catalog, Schema schema, String pattern, int types, ConfigStore configs) * List buildQueryTablesCommentRun(DataRuntime runtime, Catalog catalog, Schema schema, String pattern, int types) * [结果集封装]
* LinkedHashMap tables(DataRuntime runtime, int index, boolean create, LinkedHashMap tables, Catalog catalog, Schema schema, DataSet set) * List tables(DataRuntime runtime, int index, boolean create, List tables, Catalog catalog, Schema schema, DataSet set) * LinkedHashMap tables(DataRuntime runtime, boolean create, LinkedHashMap tables, Catalog catalog, Schema schema, String pattern, int types) * List tables(DataRuntime runtime, boolean create, List tables, Catalog catalog, Schema schema, String pattern, int types) * LinkedHashMap comments(DataRuntime runtime, int index, boolean create, LinkedHashMap tables, Catalog catalog, Schema schema, DataSet set) * [调用入口] * List ddl(DataRuntime runtime, String random, Table table, boolean init) * [命令合成] * List buildQueryDdlRun(DataRuntime runtime, Table table) * [结果集封装]
* List ddl(DataRuntime runtime, int index, Table table, List ddls, DataSet set) ******************************************************************************************************************/ /** * * table[调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param greedy 贪婪模式 true:查询权限范围内尽可能多的数据 false:只查当前catalog/schema/database范围内数据 * @param query 查询条件 根据metadata属性 * @param types 查询的类型 参考 Table.TYPE 多个类型相加算出总和 * @param struct 查询的属性 参考Metadata.TYPE 多个属性相加算出总和 true:表示查询全部 * @return List * @param Table */ @Override public List tables(DataRuntime runtime, String random, boolean greedy, Table query, int types, int struct, ConfigStore configs) { return super.tables(runtime, random, greedy, query, types, struct, configs); } /** * table[结果集封装-子流程]
* 查出所有key并以大写缓存 用来实现忽略大小写 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param query 查询条件 根据metadata属性 */ @Override protected void tableMap(DataRuntime runtime, String random, boolean greedy, Table query, ConfigStore configs) { super.tableMap(runtime, random, greedy, query, configs); } @Override public LinkedHashMap tables(DataRuntime runtime, String random, Table query, int types, int struct, ConfigStore configs) { return super.tables(runtime, random, query, types, struct, configs); } /** * table[命令合成]
* 查询表,不是查表中的数据 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param greedy 贪婪模式 true:查询权限范围内尽可能多的数据 false:只查当前catalog/schema/database范围内数据 * @param query 查询条件 根据metadata属性 * @param types 查询的类型 参考 Table.TYPE 多个类型相加算出总和 * @return String */ @Override public List buildQueryTablesRun(DataRuntime runtime, boolean greedy, Table query, int types, ConfigStore configs) throws Exception { List runs = new ArrayList<>(); Run run = new SimpleRun(runtime, configs); runs.add(run); StringBuilder builder = run.getBuilder(); builder.append("SELECT * FROM information_schema.TABLES"); configs.and("TABLE_SCHEMA", query.getSchemaName()); configs.and(Compare.LIKE_SIMPLE,"TABLE_NAME", objectName(runtime, query.getName())); List tps = names(Table.types(types)); if(tps.isEmpty()) { tps.add("BASE TABLE"); } configs.in("TABLE_TYPE", tps); return runs; } /** * Table[结果集封装]
* Table 属性与结果集对应关系 * @return MetadataFieldRefer */ @Override public MetadataFieldRefer initTableFieldRefer() { MetadataFieldRefer refer = new MetadataFieldRefer(Table.class); refer.map(Table.FIELD_NAME, "TABLE_NAME"); refer.map(Table.FIELD_SCHEMA, "TABLE_SCHEMA"); refer.map(Table.FIELD_TYPE, "TABLE_TYPE"); refer.map(Table.FIELD_ENGINE, "ENGINE"); refer.map(Table.FIELD_OBJECT_ID, "OBJECT_ID"); refer.map(Table.FIELD_DATA_ROWS, "TABLE_ROWS"); refer.map(Table.FIELD_COLLATE, "TABLE_COLLATION"); refer.map(Table.FIELD_DATA_LENGTH, "DATA_LENGTH"); refer.map(Table.FIELD_DATA_FREE, "DATA_FREE"); refer.map(Table.FIELD_INCREMENT, "AUTO_INCREMENT"); refer.map(Table.FIELD_INDEX_LENGTH, "INDEX_LENGTH"); refer.map(Table.FIELD_CREATE_TIME, "CREATE_TIME"); refer.map(Table.FIELD_UPDATE_TIME, "UPDATE_TIME"); refer.map(Table.FIELD_TEMPORARY, "IS_TEMPORARY"); refer.map(Table.FIELD_COMMENT, "TABLE_COMMENT"); refer.map(Table.FIELD_MASTER_CHECK, "CREATE_OPTIONS"); refer.map(Table.FIELD_MASTER_CHECK_VALUE, "partitioned"); return refer; } /** * Table[结果集封装]
* TableComment 属性与结果集对应关系 * @return MetadataFieldRefer */ @Override public MetadataFieldRefer initTableCommentFieldRefer() { MetadataFieldRefer refer = new MetadataFieldRefer(TableComment.class); refer.map(TableComment.FIELD_VALUE, "TABLE_COMMENT"); refer.map(TableComment.FIELD_TABLE, "TABLE_NAME"); refer.map(TableComment.FIELD_CATALOG, "TABLE_CATALOG"); refer.map(TableComment.FIELD_SCHEMA, "TABLE_SCHEMA"); return refer; } /** * table[命令合成]
* 查询表备注 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param query 查询条件 根据metadata属性 * @param types 查询的类型 参考 Table.TYPE 多个类型相加算出总和 * @return String */ @Override public List buildQueryTablesCommentRun(DataRuntime runtime, Table query, int types) throws Exception { return super.buildQueryTablesCommentRun(runtime, query, types); } /** * table[结果集封装]
* 根据查询结果集构造Table * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条SQL 对照buildQueryTablesRun返回顺序 * @param create 上一步没有查到的,这一步是否需要新创建 * @param query 查询条件 根据metadata属性 * @param previous 上一步查询结果 * @param set 查询结果集 * @return tables * @throws Exception 异常 */ @Override public LinkedHashMap tables(DataRuntime runtime, int index, boolean create, LinkedHashMap previous, Table query, DataSet set) throws Exception { set.removeColumn("TABLE_CATALOG"); previous = super.tables(runtime, index, create, previous,query, set); return previous; } /** * table[结果集封装]
* 根据查询结果集构造Table * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条SQL 对照buildQueryTablesRun返回顺序 * @param create 上一步没有查到的,这一步是否需要新创建 * @param query 查询条件 根据metadata属性 * @param previous 上一步查询结果 * @param set 查询结果集 * @return tables * @throws Exception 异常 */ @Override public List tables(DataRuntime runtime, int index, boolean create, List previous, Table query, DataSet set) throws Exception { set.removeColumn("TABLE_CATALOG"); previous = super.tables(runtime, index, create, previous, query, set); return previous; } /** * table[结果集封装]
* 根据驱动内置方法补充 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param create 上一步没有查到的,这一步是否需要新创建 * @param previous 上一步查询结果 * @param query 查询条件 根据metadata属性 * @param types 查询的类型 参考 Table.TYPE 多个类型相加算出总和 * @return tables * @throws Exception 异常 */ @Override public LinkedHashMap tables(DataRuntime runtime, boolean create, LinkedHashMap previous, Table query, int types) throws Exception { return super.tables(runtime, create, previous, query, types); } /** * table[结果集封装]
* 根据驱动内置方法补充 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param create 上一步没有查到的,这一步是否需要新创建 * @param previous 上一步查询结果 * @param query 查询条件 根据metadata属性 * @param types 查询的类型 参考 Table.TYPE 多个类型相加算出总和 * @return tables * @throws Exception 异常 */ @Override public List tables(DataRuntime runtime, boolean create, List previous, Table query, int types) throws Exception { return super.tables(runtime, create, previous, query, types); } /** * table[结果集封装]
* 表备注 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条SQL 对照buildQueryTablesRun返回顺序 * @param create 上一步没有查到的,这一步是否需要新创建 * @param query 查询条件 根据metadata属性 * @param previous 上一步查询结果 * @param set 查询结果集 * @return tables * @throws Exception 异常 */ @Override public LinkedHashMap comments(DataRuntime runtime, int index, boolean create, LinkedHashMap previous, Table query, DataSet set) throws Exception { return super.comments(runtime, index, create, previous, query, set); } /** * table[结果集封装]
* 表备注 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条SQL 对照buildQueryTablesRun返回顺序 * @param create 上一步没有查到的,这一步是否需要新创建 * @param query 查询条件 根据metadata属性 * @param previous 上一步查询结果 * @param set 查询结果集 * @return tables * @throws Exception 异常 */ @Override public List comments(DataRuntime runtime, int index, boolean create, List previous, Table query, DataSet set) throws Exception { return super.comments(runtime, index, create, previous, query, set); } /** * * table[调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param table 表 * @param init 是否还原初始状态 如自增状态 * @return List */ @Override public List ddl(DataRuntime runtime, String random, Table table, boolean init) { return super.ddl(runtime, random, table, init); } /** * table[命令合成]
* 查询表DDL * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param table 表 * @return List */ @Override public List buildQueryDdlRun(DataRuntime runtime, Table table) throws Exception { List runs = new ArrayList<>(); Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); builder.append("show create table "); name(runtime, builder, table); return runs; } /** * table[结果集封装]
* 查询表DDL * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条SQL 对照 buildQueryDdlRun 返回顺序 * @param table 表 * @param set sql执行的结果集 * @return List */ @Override public List ddl(DataRuntime runtime, int index, Table table, List ddls, DataSet set) { if(null == ddls) { ddls = new ArrayList<>(); } for(DataRow row:set) { ddls.add(row.getString("CREATE TABLE")); } if(BasicUtil.isEmpty(table.getCharset())) { for (String item : ddls) { if (item.contains("CHARSET=")) { String charset = RegularUtil.cut(item, "CHARSET="," "); table.setCharset(charset); } if(item.contains("ENGINE=")) { String engine = RegularUtil.cut(item, "ENGINE="," "); table.setEngine(engine); } } } return ddls; } /* ***************************************************************************************************************** * view * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * LinkedHashMap views(DataRuntime runtime, String random, boolean greedy, Catalog catalog, Schema schema, String pattern, int types) * [命令合成] * List buildQueryViewsRun(DataRuntime runtime, boolean greedy, Catalog catalog, Schema schema, String pattern, int types) * [结果集封装]
* LinkedHashMap views(DataRuntime runtime, int index, boolean create, LinkedHashMap views, Catalog catalog, Schema schema, DataSet set) * LinkedHashMap views(DataRuntime runtime, boolean create, LinkedHashMap views, Catalog catalog, Schema schema, String pattern, int types) * [调用入口] * List ddl(DataRuntime runtime, String random, View view) * [命令合成] * List buildQueryDdlRun(DataRuntime runtime, View view) * [结果集封装]
* List ddl(DataRuntime runtime, int index, View view, List ddls, DataSet set) ******************************************************************************************************************/ /** * view[调用入口]
* 查询视图 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param query 查询条件 根据metadata属性 * @param types 查询的类型 参考 Table.TYPE 多个类型相加算出总和 * @return List * @param View */ @Override public LinkedHashMap views(DataRuntime runtime, String random, View query, int types, int struct, ConfigStore configs) { return super.views(runtime, random, query, types, struct, configs); } /** * view[命令合成]
* 查询视图 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param greedy 贪婪模式 true:查询权限范围内尽可能多的数据 false:只查当前catalog/schema/database范围内数据 * @param query 查询条件 根据metadata属性 * @param types 查询的类型 参考 Table.TYPE 多个类型相加算出总和 * @return List */ @Override public List buildQueryViewsRun(DataRuntime runtime, boolean greedy, View query, int types, ConfigStore configs) throws Exception { List runs = new ArrayList<>(); Run run = new SimpleRun(runtime, configs); runs.add(run); StringBuilder builder = run.getBuilder(); builder.append("SELECT * FROM information_schema.VIEWS"); configs.and("TABLE_SCHEMA", query.getSchemaName()); configs.and(Compare.LIKE_SIMPLE,"TABLE_NAME", query.getName()); return runs; } /** * View[结果集封装]
* View 属性与结果集对应关系 * @return MetadataFieldRefer */ @Override public MetadataFieldRefer initViewFieldRefer() { MetadataFieldRefer refer = new MetadataFieldRefer(View.class); refer.map(View.FIELD_NAME, "TABLE_NAME"); refer.map(View.FIELD_SCHEMA, "TABLE_SCHEMA"); refer.map(View.FIELD_DEFINITION,"VIEW_DEFINITION"); return refer; } /** * view[结果集封装]
* 根据查询结果集构造View * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条SQL 对照buildQueryViewsRun返回顺序 * @param create 上一步没有查到的,这一步是否需要新创建 * @param query 查询条件 根据metadata属性 * @param previous 上一步查询结果 * @param set 查询结果集 * @return views * @throws Exception 异常 */ @Override public LinkedHashMap views(DataRuntime runtime, int index, boolean create, LinkedHashMap previous, View query, DataSet set) throws Exception { return super.views(runtime, index, create, previous, query, set); } /** * view[结果集封装]
* 根据根据驱动内置接口补充 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param create 上一步没有查到的,这一步是否需要新创建 * @param previous 上一步查询结果 * @param query 查询条件 根据metadata属性 * @param types 查询的类型 参考 Table.TYPE 多个类型相加算出总和 * @return views * @throws Exception 异常 */ @Override public LinkedHashMap views(DataRuntime runtime, boolean create, LinkedHashMap previous, View query, int types) throws Exception { return super.views(runtime, create, previous, query, types); } /** * view[调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param view 视图 * @return List */ @Override public List ddl(DataRuntime runtime, String random, View view, boolean init) { return super.ddl(runtime, random, view, init); } /** * view[命令合成]
* 查询view DDL * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param view view * @return List */ @Override public List buildQueryDdlRun(DataRuntime runtime, View view) throws Exception { List runs = new ArrayList<>(); Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); builder.append("show create view "); name(runtime, builder, view); return runs; } /** * view[结果集封装]
* 查询 view DDL * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条SQL 对照 buildQueryDdlRun 返回顺序 * @param view view * @param set sql执行的结果集 * @return List */ @Override public List ddl(DataRuntime runtime, int index, View view, List ddls, DataSet set) { if(null == ddls) { ddls = new ArrayList<>(); } for(DataRow row:set) { ddls.add(row.getString("CREATE VIEW")); } return ddls; } /* ***************************************************************************************************************** * master table * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * LinkedHashMap masters(DataRuntime runtime, String random, Catalog catalog, Schema schema, String pattern, int types, int struct, ConfigStore configs) * [命令合成] * List buildQueryMasterTablesRun(DataRuntime runtime, Catalog catalog, Schema schema, String pattern, int types, ConfigStore configs) * [结果集封装]
* LinkedHashMap masters(DataRuntime runtime, int index, boolean create, LinkedHashMap tables, Catalog catalog, Schema schema, DataSet set) * [结果集封装]
* LinkedHashMap masters(DataRuntime runtime, boolean create, LinkedHashMap tables,Catalog catalog, Schema schema, String pattern, int types) * [调用入口] * List ddl(DataRuntime runtime, String random, MasterTable table) * [命令合成] * List buildQueryDdlRun(DataRuntime runtime, MasterTable table) * [结果集封装]
* List ddl(DataRuntime runtime, int index, MasterTable table, List ddls, DataSet set) ******************************************************************************************************************/ /** * master table[调用入口]
* 查询主表 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param greedy 贪婪模式 true:查询权限范围内尽可能多的数据 false:只查当前catalog/schema/database范围内数据 * @param query 查询条件 根据metadata属性 * @param types 查询的类型 参考 Table.TYPE 多个类型相加算出总和 * @return List * @param MasterTable */ @Override public List masters(DataRuntime runtime, String random, boolean greedy, MasterTable query, int types, int struct, ConfigStore configs) { return super.masters(runtime, random, greedy, query, types, struct, configs); } /** * master table[命令合成]
* 查询主表 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param query 查询条件 根据metadata属性 * @param types 查询的类型 参考 Table.TYPE 多个类型相加算出总和 * @return String */ @Override public List buildQueryMasterTablesRun(DataRuntime runtime, boolean greedy, MasterTable query, int types, ConfigStore configs) throws Exception { return super.buildQueryMasterTablesRun(runtime, greedy, query, types, configs); } /** * master[结果集封装]
* MasterTable 属性与结果集对应关系 * @return MetadataFieldRefer */ @Override public MetadataFieldRefer initMasterTableFieldRefer() { return super.initMasterTableFieldRefer(); } /** * master table[结果集封装]
* 根据查询结果集构造Table * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条SQL 对照 buildQueryMasterTablesRun返回顺序 * @param create 上一步没有查到的,这一步是否需要新创建 * @param query 查询条件 根据metadata属性 * @param previous 上一步查询结果 * @param set 查询结果集 * @return tables * @throws Exception 异常 */ @Override public LinkedHashMap masters(DataRuntime runtime, int index, boolean create, LinkedHashMap previous, MasterTable query, DataSet set) throws Exception { return super.masters(runtime, index, create, previous, query, set); } /** * master table[结果集封装]
* 根据根据驱动内置接口 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param create 上一步没有查到的,这一步是否需要新创建 * @param query 查询条件 根据metadata属性 * @param previous 上一步查询结果 * @return tables * @throws Exception 异常 */ @Override public LinkedHashMap masters(DataRuntime runtime, boolean create, LinkedHashMap previous, MasterTable query, int types) throws Exception { return super.masters(runtime, create, previous, query, types); } /** * master table[调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param meta MasterTable * @return List */ @Override public List ddl(DataRuntime runtime, String random, MasterTable meta, boolean init) { return super.ddl(runtime, random, meta, init); } /** * master table[命令合成]
* 查询 MasterTable DDL * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta MasterTable * @return List */ @Override public List buildQueryDdlRun(DataRuntime runtime, MasterTable meta) throws Exception { return super.buildQueryDdlRun(runtime, meta); } /** * master table[结果集封装]
* 查询 MasterTable DDL * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条SQL 对照 buildQueryDdlRun 返回顺序 * @param table MasterTable * @param set sql执行的结果集 * @return List */ @Override public List ddl(DataRuntime runtime, int index, MasterTable table, List ddls, DataSet set) { return super.ddl(runtime, index, table, ddls, set); } /* ***************************************************************************************************************** * partition table * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * LinkedHashMap partitions(DataRuntime runtime, String random, boolean greedy, MasterTable master, Map tags, String pattern) * [命令合成] * List buildQueryPartitionTablesRun(DataRuntime runtime, boolean greedy, Catalog catalog, Schema schema, String pattern, int types) * List buildQueryPartitionTablesRun(DataRuntime runtime, boolean greedy, Table master, Map tags, String pattern) * List buildQueryPartitionTablesRun(DataRuntime runtime, boolean greedy, Table master, Map tags) * [结果集封装]
* LinkedHashMap partitions(DataRuntime runtime, int total, int index, boolean create, MasterTable master, LinkedHashMap tables, Catalog catalog, Schema schema, DataSet set) * LinkedHashMap partitions(DataRuntime runtime, boolean create, LinkedHashMap tables, Catalog catalog, Schema schema, MasterTable master) * [调用入口] * List ddl(DataRuntime runtime, String random, PartitionTable table) * [命令合成] * List buildQueryDdlRun(DataRuntime runtime, PartitionTable table) * [结果集封装]
* List ddl(DataRuntime runtime, int index, PartitionTable table, List ddls, DataSet set) ******************************************************************************************************************/ /** * 表分区方式及分片 * @param table 主表 * @return Partition */ public Table.Partition partition(DataRuntime runtime, String random, Table table) { return super.partition(runtime, random, table); } /** * partition table[命令合成]
* 查询表分区方式及分片 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param table 表 * @return String */ @Override public List buildQueryTablePartitionRun(DataRuntime runtime, Table table) { List runs = new ArrayList<>(); SimpleRun run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); //分区方式 builder.append("SHOW CREATE TABLE "); name(runtime, builder, table); //分区 run = new SimpleRun(runtime); runs.add(run); builder = run.getBuilder(); builder.append("SELECT * FROM information_schema.PARTITIONS"); ConfigStore configs = run.getConfigs(); configs.and("TABLE_SCHEMA", table.getSchemaName()); configs.and("TABLE_NAME", table.getName()); return runs; } /** * partition table[结果集封装]
* 根据查询结果集构造Table * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条SQL 对照 buildQueryMasterTablesRun返回顺序 * @param create 上一步没有查到的,这一步是否需要新创建 * @param meta 上一步查询结果 * @param table 表 * @param set 查询结果集 * @return tables * @throws Exception 异常 */ @Override public Table.Partition partition(DataRuntime runtime, int index, boolean create, Table.Partition meta, Table table, DataSet set) throws Exception { return super.partition(runtime, index, create, meta, table, set); } /** * partition table[结果集封装]
* 根据查询结果集构造Table.Partition * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条SQL 对照 buildQueryMasterTablesRun返回顺序 * @param create 上一步没有查到的,这一步是否需要新创建 * @param meta 上一步查询结果 * @param table 表 * @param row 查询结果集 * @return tables * @throws Exception 异常 */ @Override public Table.Partition init(DataRuntime runtime, int index, boolean create, Table.Partition meta, Table table, DataRow row) throws Exception { MetadataFieldRefer refer = refer(runtime, Table.Partition.class); if(index == 0) { String txt = row.getString("Create Table"); if(null != txt) { /* PARTITION BY HASH (`ID`) PARTITIONS 100 注意忽略大小写 mysql:大写 ocean base:小写 */ String type = RegularUtil.cut(true, txt, "PARTITION BY", "("); if(null != type) { meta = new Table.Partition(); type = type.trim(); Table.Partition.TYPE ty = Table.Partition.TYPE.valueOf(type.toUpperCase()); meta.setType(ty); String[] columns = RegularUtil.cut(true, txt, "PARTITION BY", "(", ")").split(","); for(String column:columns) { meta.addColumn(column.replace("`", "").trim()); } if(ty == Table.Partition.TYPE.HASH) { String mod = RegularUtil.cut(true, txt, "PARTITION BY", "PARTITIONS", " ", " "); if(null != mod) { meta.setModulus(BasicUtil.parseInt(mod.trim(), -1)); } } } } } return meta; } /** * partition table[结果集封装]
* 根据查询结果集构造Table.Partition * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条SQL 对照 buildQueryMasterTablesRun返回顺序 * @param create 上一步没有查到的,这一步是否需要新创建 * @param meta 上一步查询结果 * @param table 表 * @param row 查询结果集 * @return tables * @throws Exception 异常 */ @Override public Table.Partition detail(DataRuntime runtime, int index, boolean create, Table.Partition meta, Table table, DataRow row) throws Exception { if(index == 1) { MetadataFieldRefer refer = refer(runtime, Table.Partition.Slice.class); Table.Partition.Slice slice = new Table.Partition.Slice(); slice.setName(getString(row, refer, Table.Partition.Slice.FIELD_NAME)); Table.Partition.TYPE type = meta.getType(); if(type == Table.Partition.TYPE.LIST) { String[] values = row.getString("PARTITION_DESCRIPTION").split(","); for(String value:values) { slice.addValue(value); } }else if(type == Table.Partition.TYPE.RANGE) { String[] less = row.getString("PARTITION_DESCRIPTION").split(","); String[] columns = row.getString("PARTITION_EXPRESSION").replace("`","").split(","); int size = columns.length; for(int i=0; i * Table.Partition 属性与结果集对应关系 * @return MetadataFieldRefer */ @Override public MetadataFieldRefer initTablePartitionFieldRefer() { MetadataFieldRefer refer = new MetadataFieldRefer(Table.Partition.class); refer.map(Table.Partition.FIELD_TYPE, "PARTITION_METHOD"); refer.map(Table.Partition.FIELD_COLUMN, "PARTITION_EXPRESSION"); return refer; } /** * partition table[结果集封装]
* Table.Partition.Slice 属性与结果集对应关系 * @return MetadataFieldRefer */ @Override public MetadataFieldRefer initTablePartitionSliceFieldRefer() { MetadataFieldRefer refer = new MetadataFieldRefer(Table.Partition.Slice.class); refer.map(Table.Partition.Slice.FIELD_NAME, "PARTITION_NAME"); return refer; } /** * partition table[调用入口]
* 查询主表 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param greedy 贪婪模式 true:查询权限范围内尽可能多的数据 false:只查当前catalog/schema/database范围内数据 * @param query 查询条件 根据metadata属性 * @return List * @param MasterTable */ @Override public LinkedHashMap partitions(DataRuntime runtime, String random, boolean greedy, PartitionTable query) { return super.partitions(runtime, random, greedy, query); } /** * partition table[命令合成]
* 查询分区表 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param query 查询条件 根据metadata属性 * @param types 查询的类型 参考 Table.TYPE 多个类型相加算出总和 * @return String */ @Override public List buildQueryPartitionTablesRun(DataRuntime runtime, boolean greedy, PartitionTable query, int types) throws Exception { return super.buildQueryPartitionTablesRun(runtime, greedy, query, types); } /** * partition table[结果集封装]
* 根据查询结果集构造Table * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param total 合计SQL数量 * @param index 第几条SQL 对照 buildQueryMasterTablesRun返回顺序 * @param create 上一步没有查到的,这一步是否需要新创建 * @param query 查询条件 根据metadata属性 * @param previous 上一步查询结果 * @param set 查询结果集 * @return tables * @throws Exception 异常 */ @Override public LinkedHashMap partitions(DataRuntime runtime, int total, int index, boolean create, LinkedHashMap previous, PartitionTable query, DataSet set) throws Exception { return super.partitions(runtime, total, index, create, previous, query, set); } /** * partition table[结果集封装]
* 根据根据驱动内置接口 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param create 上一步没有查到的,这一步是否需要新创建 * @param query 查询条件 根据metadata属性 * @param previous 上一步查询结果 * @return tables * @throws Exception 异常 */ @Override public LinkedHashMap partitions(DataRuntime runtime, boolean create, LinkedHashMap previous, PartitionTable query) throws Exception { return super.partitions(runtime, create, previous, query); } /** * partition table[调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param table PartitionTable * @return List */ @Override public List ddl(DataRuntime runtime, String random, PartitionTable table) { return super.ddl(runtime, random, table); } /** * partition table[命令合成]
* 查询 PartitionTable DDL * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param table PartitionTable * @return List */ @Override public List buildQueryDdlRun(DataRuntime runtime, PartitionTable table) throws Exception { return super.buildQueryDdlRun(runtime, table); } /** * partition table[结果集封装]
* 查询 MasterTable DDL * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条SQL 对照 buildQueryDdlRun 返回顺序 * @param table MasterTable * @param set sql执行的结果集 * @return List */ @Override public List ddl(DataRuntime runtime, int index, PartitionTable table, List ddls, DataSet set) { return super.ddl(runtime, index, table, ddls, set); } /* ***************************************************************************************************************** * column * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * LinkedHashMap columns(DataRuntime runtime, String random, boolean greedy, Table table, boolean primary); * List columns(DataRuntime runtime, String random, boolean greedy, Catalog catalog, Schema schema, String table); * [命令合成] * List buildQueryColumnsRun(DataRuntime runtime, Table table, boolean metadata) throws Exception; * [结果集封装]
* LinkedHashMap columns(DataRuntime runtime, int index, boolean create, LinkedHashMap previous, Table table, Column query, DataSet set) throws Exception; * List columns(DataRuntime runtime, int index, boolean create, List previous, Column query, DataSet set) throws Exception; * LinkedHashMap columns(DataRuntime runtime, boolean create, LinkedHashMap columns, Table table, String pattern) throws Exception; ******************************************************************************************************************/ /** * column[调用入口]
* 查询表结构 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param greedy 贪婪模式 true:如果不填写catalog或schema则查询全部 false:只在当前catalog和schema中查询 * @param table 表 * @param primary 是否检测主键 * @return Column * @param Column */ @Override public LinkedHashMap columns(DataRuntime runtime, String random, boolean greedy, Table table, Column query, boolean primary, ConfigStore configs) { return super.columns(runtime, random, greedy, table, query, primary, configs); } /** * column[命令合成]
* 查询表上的列 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param query 查询条件 根据metadata属性 * @param metadata 是否根据metadata(true:SELECT * FROM T WHERE 1=0,false:查询系统表) * @return runs */ @Override public List buildQueryColumnsRun(DataRuntime runtime, boolean metadata, Column query, ConfigStore configs) throws Exception { List runs = new ArrayList<>(); Table table = query.getTable(); Run run = new SimpleRun(runtime, configs); runs.add(run); StringBuilder builder = run.getBuilder(); if(metadata) { builder.append("SELECT * FROM "); name(runtime, builder, table); builder.append(" WHERE 1=0"); }else{ builder.append("SELECT * FROM INFORMATION_SCHEMA.COLUMNS"); //mysql忽略catalog configs.and("TABLE_SCHEMA", query.getSchemaName()); configs.and(Compare.LIKE_SIMPLE, "TABLE_NAME", objectName(runtime, query.getTableName())); configs.order("TABLE_NAME").order("ORDINAL_POSITION"); } return runs; } /** * Column[结果集封装]
* Column 属性与结果集对应关系 * @return MetadataFieldRefer */ @Override public MetadataFieldRefer initColumnFieldRefer() { MetadataFieldRefer refer = new MetadataFieldRefer(Column.class); refer.map(Column.FIELD_NAME, "COLUMN_NAME"); refer.map(Column.FIELD_CATALOG, "");//忽略 refer.map(Column.FIELD_SCHEMA, "TABLE_SCHEMA"); refer.map(Column.FIELD_TABLE, "TABLE_NAME"); refer.map(Column.FIELD_NULLABLE, "IS_NULLABLE"); refer.map(Column.FIELD_CHARSET, "CHARACTER_SET_NAME"); refer.map(Column.FIELD_COLLATE, "COLLATION_NAME"); refer.map(Column.FIELD_TYPE, "COLUMN_TYPE"); refer.map(Column.FIELD_POSITION, "ORDINAL_POSITION"); refer.map(Column.FIELD_COMMENT, "COLUMN_COMMENT"); refer.map(Column.FIELD_DEFAULT_VALUE, "COLUMN_DEFAULT"); refer.map(Column.FIELD_AUTO_INCREMENT_CHECK, "EXTRA"); refer.map(Column.FIELD_AUTO_INCREMENT_CHECK_VALUE, "auto_increment"); refer.map(Column.FIELD_ON_UPDATE_CHECK, "EXTRA"); refer.map(Column.FIELD_ON_UPDATE_CHECK_VALUE, ".*on update.*"); refer.map(Column.FIELD_PRIMARY_CHECK,"COLUMN_KEY"); refer.map(Column.FIELD_PRIMARY_CHECK_VALUE,"PRI"); return refer; } /** * column[命令合成]
* 查询表上的列 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param tables 表 * @param metadata 是否根据metadata(true:SELECT * FROM T WHERE 1=0,false:查询系统表) * @return runs */ @Override public List buildQueryColumnsRun(DataRuntime runtime, boolean metadata, Collection tables, Column query, ConfigStore configs) throws Exception { Schema schema = query.getSchema(); List runs = new ArrayList<>(); Table table = null; if(!tables.isEmpty()) { table = tables.iterator().next(); } if(null != table) { checkName(runtime, null, table); schema = table.getSchema(); } Run run = new SimpleRun(runtime, configs); runs.add(run); StringBuilder builder = run.getBuilder(); builder.append("SELECT * FROM INFORMATION_SCHEMA.COLUMNS"); if(!empty(schema)) { configs.and("TABLE_SCHEMA", schema.getName()); } List names = Table.names(tables); configs.in("TABLE_NAME", names); configs.order("TABLE_NAME").order("ORDINAL_POSITION"); return runs; } /** * column[结果集封装]
* 根据查询结果集构造Tag * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条SQL 对照 buildQueryColumnsRun返回顺序 * @param create 上一步没有查到的,这一步是否需要新创建 * @param table 表 * @param previous 上一步查询结果 * @param set 查询结果集 * @return tags tags * @throws Exception 异常 */ @Override public LinkedHashMap columns(DataRuntime runtime, int index, boolean create, LinkedHashMap previous, Table table, Column query, DataSet set) throws Exception { set.removeColumn("TABLE_CATALOG"); return super.columns(runtime, index, create, previous, table, query, set); } @Override public List columns(DataRuntime runtime, int index, boolean create, List previous, Column query, DataSet set) throws Exception { set.removeColumn("TABLE_CATALOG"); return super.columns(runtime, index, create, previous, query, set); } /** * column[结果集封装]
(方法1)
* 列基础属性 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 上一步封装结果 * @param query 查询条件 根据metadata属性 * @param row 系统表查询SQL结果集 * @param Column */ @Override public T init(DataRuntime runtime, int index, T meta, Column query, DataRow row) { return super.init(runtime, index, meta, query, row); } /** * column[结果集封装]
(方法1)
* 列详细属性 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 上一步封装结果 * @param row 系统表查询SQL结果集 * @return Column * @param Column */ @Override public T detail(DataRuntime runtime, int index, T meta, Column query, DataRow row) { T result = super.detail(runtime, index, meta, query, row); String onupdate = null; String extra = row.getString("EXTRA"); if(null != extra) { if(extra.contains("on update")) { onupdate = RegularUtil.cut(extra, "on update", " "); if(BasicUtil.isEmpty(onupdate)) { onupdate = RegularUtil.cut(extra, "on update", RegularUtil.TAG_END); } } } if(null != onupdate) { meta.setOnUpdate(onupdate); } return result; } /** * column[结构集封装-依据]
* 读取column元数据结果集的依据(需要区分数据类型) * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 具体数据类型,length/precisoin/scale三个属性需要根据数据类型覆盖通用配置 * @return ColumnMetadataAdapter */ @Override public TypeMetadata.Refer dataTypeMetadataRefer(DataRuntime runtime, TypeMetadata meta) { return super.dataTypeMetadataRefer(runtime, meta); } /* ***************************************************************************************************************** * tag * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * LinkedHashMap tags(DataRuntime runtime, String random, boolean greedy, Table table, Tag query) * [命令合成] * List buildQueryTagsRun(DataRuntime runtime, boolean greedy, Tag query) * [结果集封装]
* LinkedHashMap tags(DataRuntime runtime, int index, boolean create, LinkedHashMap previous, Tag query, DataSet set) * LinkedHashMap tags(DataRuntime runtime, boolean create, LinkedHashMap tags, Table table, String pattern) ******************************************************************************************************************/ /** * tag[调用入口]
* 查询表结构 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param greedy 贪婪模式 true:如果不填写catalog或schema则查询全部 false:只在当前catalog和schema中查询 * @param query 查询条件 根据metadata属性 * @return Tag * @param Tag */ @Override public LinkedHashMap tags(DataRuntime runtime, String random, boolean greedy, Table table, Tag query) { return super.tags(runtime, random, greedy, table, query); } /** * tag[命令合成]
* 查询表上的列 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param query 查询条件 根据mdtadata属性 * @return runs */ @Override public List buildQueryTagsRun(DataRuntime runtime, boolean greedy, Tag query) throws Exception { return new ArrayList<>(); } /** * tag[结果集封装]
* 根据查询结果集构造Tag * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条查询SQL 对照 buildQueryTagsRun返回顺序 * @param create 上一步没有查到的,这一步是否需要新创建 * @param previous 上一步查询结果 * @param set 查询结果集 * @return tags * @throws Exception 异常 */ @Override public LinkedHashMap tags(DataRuntime runtime, int index, boolean create, LinkedHashMap previous, Tag query, DataSet set) throws Exception { return super.tags(runtime, index, create, previous, query, set); } /** * * tag[结果集封装]
* 解析JDBC get columns结果 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param create 上一步没有查到的,这一步是否需要新创建 * @param query 查询条件 根据metadata属性 * @param previous 上一步查询结果 * @return tags * @throws Exception 异常 */ @Override public LinkedHashMap tags(DataRuntime runtime, boolean create, LinkedHashMap previous, Tag query) throws Exception { return super.tags(runtime, create, previous, query); } /* ***************************************************************************************************************** * primary * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * PrimaryKey primary(DataRuntime runtime, String random, boolean greedy, Table table) * [命令合成] * List buildQueryPrimaryRun(DataRuntime runtime, boolean greedy, Table table) throws Exception * [结构集封装] * T init(DataRuntime runtime, int index, T primary, Table table, DataSet set) ******************************************************************************************************************/ /** * primary[调用入口]
* 查询主键 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param greedy 贪婪模式 true:如果不填写catalog或schema则查询全部 false:只在当前catalog和schema中查询 * @param query 查询条件 根据metadata属性 * @return PrimaryKey */ @Override public PrimaryKey primary(DataRuntime runtime, String random, boolean greedy, PrimaryKey query) { return super.primary(runtime, random, greedy, query); } /** * primary[命令合成]
* 查询表上的主键 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param query 查询条件 根据metadata属性 * @return runs */ @Override public List buildQueryPrimaryRun(DataRuntime runtime, boolean greedy, PrimaryKey query) throws Exception { Table table = query.getTable(); List runs = new ArrayList<>(); Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); builder.append("SHOW INDEX FROM "); name(runtime, builder, table); return runs; } /** * primary[结果集封装]
* PrimaryKey 属性与结果集对应关系 * @return MetadataFieldRefer */ @Override public MetadataFieldRefer initPrimaryKeyFieldRefer() { return super.initPrimaryKeyFieldRefer(); } /** * primary[结构集封装]
* 根据查询结果集构造PrimaryKey * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条查询SQL 对照 buildQueryIndexesRun 返回顺序 * @param query 查询条件 根据metadata属性 * @param set sql查询结果 * @throws Exception 异常 */ @Override public T init(DataRuntime runtime, int index, T primary, PrimaryKey query, DataSet set) throws Exception { set = set.getRows("Key_name","PRIMARY"); if(!set.isEmpty()) { primary = (T)new PrimaryKey(); for(DataRow row:set) { primary.setName(row.getString("Key_name")); Column column = new Column(row.getString("Column_name")); primary.addColumn(column); } } return primary; } /* ***************************************************************************************************************** * foreign * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * LinkedHashMap foreigns(DataRuntime runtime, String random, boolean greedy, Table table); * [命令合成] * List buildQueryForeignsRun(DataRuntime runtime, boolean greedy, Table table) throws Exception; * [结构集封装] * LinkedHashMap foreigns(DataRuntime runtime, int index, Table table, LinkedHashMap foreigns, DataSet set) throws Exception; ******************************************************************************************************************/ /** * foreign[调用入口]
* 查询外键 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param greedy 贪婪模式 true:如果不填写catalog或schema则查询全部 false:只在当前catalog和schema中查询 * @param query 查询条件 根据metadata属性 * @return PrimaryKey */ @Override public LinkedHashMap foreigns(DataRuntime runtime, String random, boolean greedy, ForeignKey query) { return super.foreigns(runtime, random, greedy, query); } /** * foreign[命令合成]
* 查询表上的外键 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param query 查询条件 根据metadata属性 * @return runs */ @Override public List buildQueryForeignsRun(DataRuntime runtime, boolean greedy, ForeignKey query) throws Exception { List runs = new ArrayList<>(); Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); ConfigStore configs = run.getConfigs(); builder.append("SELECT * FROM INFORMATION_SCHEMA.KEY_COLUMN_USAGE where REFERENCED_TABLE_NAME IS NOT NULL\n"); configs.and(Compare.LIKE_SIMPLE, "TABLE_NAME", query.getTableName()); configs.order("ORDINAL_POSITION"); return runs; } /** * foreign[结果集封装]
* ForeignKey 属性与结果集对应关系 * @return MetadataFieldRefer */ @Override public MetadataFieldRefer initForeignKeyFieldRefer() { MetadataFieldRefer refer = new MetadataFieldRefer(ForeignKey.class); refer.map(ForeignKey.FIELD_NAME, "CONSTRAINT_NAME"); refer.map(ForeignKey.FIELD_CATALOG, ""); refer.map(ForeignKey.FIELD_SCHEMA, "REFERENCED_SCHEMA_NAME"); refer.map(ForeignKey.FIELD_TABLE, "TABLE_NAME"); refer.map(ForeignKey.FIELD_COLUMN, "COLUMN_NAME"); refer.map(ForeignKey.FIELD_COLUMN_POSITION, "ORDINAL_POSITION"); refer.map(ForeignKey.FIELD_REFERENCE_CATALOG, ""); refer.map(ForeignKey.FIELD_REFERENCE_SCHEMA, "REFERENCED_SCHEMA_NAME"); refer.map(ForeignKey.FIELD_REFERENCE_TABLE, "REFERENCED_TABLE_NAME"); refer.map(ForeignKey.FIELD_REFERENCE_COLUMN, "REFERENCED_COLUMN_NAME"); return refer; } /** * * foreign[结构集封装]
* 根据查询结果集构造PrimaryKey * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条查询SQL 对照 buildQueryForeignsRun 返回顺序 * @param query 查询条件 根据metadata属性 * @param previous 上一步查询结果 * @param set sql查询结果 * @throws Exception 异常 */ @Override public LinkedHashMap foreigns(DataRuntime runtime, int index, LinkedHashMap previous, ForeignKey query, DataSet set) throws Exception { return super.foreigns(runtime, index, previous, query, set); } /** * foreign[结构集封装]
* 根据查询结果集构造ForeignKey基础属性 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条查询SQL 对照 buildQueryIndexesRun 返回顺序 * @param meta 上一步封装结果 * @param query 查询条件 根据metadata属性 * @param row sql查询结果 * @throws Exception 异常 */ @Override public T init(DataRuntime runtime, int index, T meta, ForeignKey query, DataRow row) throws Exception { return super.init(runtime, index, meta, query, row); } /** * foreign[结构集封装]
* 根据查询结果集构造ForeignKey更多属性 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条查询SQL 对照 buildQueryIndexesRun 返回顺序 * @param meta 上一步封装结果 * @param query 查询条件 根据metadata属性 * @param row sql查询结果 * @throws Exception 异常 */ @Override public T detail(DataRuntime runtime, int index, T meta, ForeignKey query, DataRow row) throws Exception { return super.detail(runtime, index, meta, query, row); } /* ***************************************************************************************************************** * index * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * List indexes(DataRuntime runtime, String random, boolean greedy, Table table, String pattern) * LinkedHashMap indexes(DataRuntime runtime, String random, Table table, String pattern) * [命令合成] * List buildQueryIndexesRun(DataRuntime runtime, boolean greedy, Table table, String name) * [结果集封装]
* List indexes(DataRuntime runtime, int index, boolean create, Table table, List indexes, DataSet set) * LinkedHashMap indexes(DataRuntime runtime, int index, boolean create, Table table, LinkedHashMap indexes, DataSet set) * List indexes(DataRuntime runtime, boolean create, List indexes, Table table, boolean unique, boolean approximate) * LinkedHashMap indexes(DataRuntime runtime, boolean create, LinkedHashMap indexes, Table table, boolean unique, boolean approximate) ******************************************************************************************************************/ /** * * index[调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param greedy 贪婪模式 true:如果不填写catalog或schema则查询全部 false:只在当前catalog和schema中查询 * @param query 查询条件 根据metadata属性 * @return LinkedHashMap * @param Index */ @Override public List indexes(DataRuntime runtime, String random, boolean greedy, Index query) { return super.indexes(runtime, random, greedy, query); } /** * * index[调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param query 查询条件 根据metadata属性 * @return LinkedHashMap * @param Index */ @Override public LinkedHashMap indexes(DataRuntime runtime, String random, Index query) { return super.indexes(runtime, random, query); } /** * index[命令合成]
* 查询表上的索引 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param query 查询条件 根据metadata属性 * @return runs */ @Override public List buildQueryIndexesRun(DataRuntime runtime, boolean greedy, Index query) { List runs = new ArrayList<>(); Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); ConfigStore configs = run.getConfigs(); builder.append("SELECT * FROM INFORMATION_SCHEMA.STATISTICS\n"); configs.and("TABLE_SCHEMA", query.getSchemaName()); configs.and(Compare.LIKE_SIMPLE,"TABLE_NAME", query.getTableName()); configs.and(Compare.LIKE_SIMPLE,"INDEX_NAME", query.getName()); configs.order("SEQ_IN_INDEX"); return runs; } @Override public List buildQueryIndexesRun(DataRuntime runtime, boolean greedy, Collection tables) { List runs = new ArrayList<>(); Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); ConfigStore configs = run.getConfigs(); builder.append("SELECT * FROM INFORMATION_SCHEMA.STATISTICS\n"); if(null != tables && !tables.isEmpty()) { Table table = tables.iterator().next(); configs.and("TABLE_SCHEMA", table.getSchemaName()); } configs.in("TABLE_NAME", Table.names(tables)); configs.order("TABLE_NAME").order("SEQ_IN_INDEX"); return runs; } /** * Index[结果集封装]
* Index 属性与结果集对应关系 * @return MetadataFieldRefer */ @Override public MetadataFieldRefer initIndexFieldRefer() { MetadataFieldRefer refer = new MetadataFieldRefer(Index.class); refer.map(Index.FIELD_NAME, "INDEX_NAME"); refer.map(Index.FIELD_TABLE, "TABLE_NAME"); refer.map(Index.FIELD_SCHEMA, "TABLE_SCHEMA"); refer.map(Index.FIELD_COLUMN, "COLUMN_NAME"); refer.map(Index.FIELD_ORDER, "COLLATION"); //A:ASC refer.map(Index.FIELD_POSITION, "SEQ_IN_INDEX"); refer.map(Index.FIELD_PRIMARY_CHECK, "INDEX_NAME"); refer.map(Index.FIELD_PRIMARY_CHECK_VALUE,"PRIMARY"); refer.map(Index.FIELD_UNIQUE_CHECK, "NON_UNIQUE"); refer.map(Index.FIELD_UNIQUE_CHECK_VALUE, "0"); refer.map(Index.FIELD_CATALOG, ""); return refer; } /** * index[结果集封装]
* 根据查询结果集构造Index * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条查询SQL 对照 buildQueryIndexesRun 返回顺序 * @param create 上一步没有查到的,这一步是否需要新创建 * @param query 查询条件 根据metadata属性 * @param previous 上一步查询结果 * @param set 查询结果集 * @return indexes indexes * @throws Exception 异常 */ @Override public LinkedHashMap indexes(DataRuntime runtime, int index, boolean create, LinkedHashMap previous, Index query, DataSet set) throws Exception { return super.indexes(runtime, index, create, previous, query, set); } /** * index[结果集封装]
* 根据查询结果集构造Index * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条查询SQL 对照 buildQueryIndexesRun 返回顺序 * @param create 上一步没有查到的,这一步是否需要新创建 * @param query 查询条件 根据metadata属性 * @param previous 上一步查询结果 * @param set 查询结果集 * @return indexes indexes * @throws Exception 异常 */ @Override public List indexes(DataRuntime runtime, int index, boolean create, List previous, Index query, DataSet set) throws Exception { return super.indexes(runtime, index, create, previous, query, set); } /** * index[结果集封装]
* 根据驱动内置接口 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param create 上一步没有查到的,这一步是否需要新创建 * @param query 查询条件 根据metadata属性 * @return indexes indexes * @throws Exception 异常 */ @Override public List indexes(DataRuntime runtime, boolean create, List previous, Index query) throws Exception { return super.indexes(runtime, create, previous, query); } /** * index[结果集封装]
* 根据驱动内置接口 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param create 上一步没有查到的,这一步是否需要新创建 * @param query 查询条件 根据metadata属性 * @return indexes indexes * @throws Exception 异常 */ @Override public LinkedHashMap indexes(DataRuntime runtime, boolean create, LinkedHashMap previous, Index query) throws Exception { return super.indexes(runtime, create, previous, query); } /** * index[结构集封装]
* 根据查询结果集构造index基础属性(name,table,schema,catalog) * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条查询SQL 对照 buildQueryIndexesRun 返回顺序 * @param meta 上一步封装结果 * @param query 查询条件 根据metadata属性 * @param row sql查询结果 * @throws Exception 异常 */ @Override public T init(DataRuntime runtime, int index, T meta, Index query, DataRow row) throws Exception { return super.init(runtime, index, meta, query, row); } /** * index[结构集封装]
* 根据查询结果集构造index更多属性(column,order, position) * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条查询SQL 对照 buildQueryIndexesRun 返回顺序 * @param meta 上一步封装结果 * @param query 查询条件 根据metadata属性 * @param row sql查询结果 * @throws Exception 异常 */ @Override public T detail(DataRuntime runtime, int index, T meta, Index query, DataRow row) throws Exception { meta = super.detail(runtime, index, meta, query, row); if(row.getBoolean("PRIMARY_KEY", false)) { meta.setPrimary(true); } return meta; } /* ***************************************************************************************************************** * constraint * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * List constraints(DataRuntime runtime, String random, boolean greedy, Table table, String pattern); * LinkedHashMap constraints(DataRuntime runtime, String random, Table table, Column column, String pattern); * [命令合成] * List buildQueryConstraintsRun(DataRuntime runtime, boolean greedy, Table table, Column column, String pattern) ; * [结果集封装]
* List constraints(DataRuntime runtime, int index, boolean create, Table table, List constraints, DataSet set) throws Exception; * LinkedHashMap constraints(DataRuntime runtime, int index, boolean create, Table table, Column column, LinkedHashMap constraints, DataSet set) throws Exception; ******************************************************************************************************************/ /** * * constraint[调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param greedy 贪婪模式 true:如果不填写catalog或schema则查询全部 false:只在当前catalog和schema中查询 * @param query 查询条件 根据metadata属性 * @return LinkedHashMap * @param Index */ @Override public List constraints(DataRuntime runtime, String random, boolean greedy, Constraint query) { return super.constraints(runtime, random, greedy, query); } /** * * constraint[调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param table 表 * @param column 列 * @param pattern 名称统配符或正则 * @return LinkedHashMap * @param Index */ @Override public LinkedHashMap constraints(DataRuntime runtime, String random, Table table, Column column, String pattern) { return super.constraints(runtime, random, table, column, pattern); } /** * constraint[命令合成]
* 查询表上的约束 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param query 查询条件 根据metadata属性 * @return runs */ @Override public List buildQueryConstraintsRun(DataRuntime runtime, boolean greedy, Constraint query) { Table table = query.getTable(); LinkedHashMap columns = query.getColumns(); List runs = new ArrayList<>(); Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); ConfigStore configs = run.getConfigs(); builder.append("SELECT * FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS"); configs.and("CONSTRAINT_CATALOG", query.getCatalogName()); configs.and("CONSTRAINT_SCHEMA", query.getSchemaName()); configs.and(Compare.LIKE_SIMPLE, "TABLE_NAME", query.getTableName()); return runs; } /** * constraint[结果集封装]
* Constraint 属性与结果集对应关系 * @return MetadataFieldRefer */ @Override public MetadataFieldRefer initConstraintFieldRefer() { MetadataFieldRefer refer = new MetadataFieldRefer(Constraint.class); refer.map(Constraint.FIELD_NAME, "CONSTRAINT_NAME"); refer.map(Constraint.FIELD_SCHEMA, "CONSTRAINT_CATALOG"); refer.map(Constraint.FIELD_TABLE, "TABLE_NAME"); refer.map(Constraint.FIELD_TYPE, "CONSTRAINT_TYPE"); return refer; } /** * constraint[结果集封装]
* 根据查询结果集构造Constraint * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条查询SQL 对照 buildQueryConstraintsRun 返回顺序 * @param create 上一步没有查到的,这一步是否需要新创建 * @param query 查询条件 根据metadata属性 * @param previous 上一步查询结果 * @param set DataSet * @return constraints constraints * @throws Exception 异常 */ @Override public List constraints(DataRuntime runtime, int index, boolean create, List previous, Constraint query, DataSet set) throws Exception { set.removeColumn("CONSTRAINT_CATALOG"); return super.constraints(runtime, index, create, previous, query, set); } /** * constraint[结果集封装]
* 根据查询结果集构造Constraint * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条查询SQL 对照 buildQueryConstraintsRun 返回顺序 * @param create 上一步没有查到的,这一步是否需要新创建 * @param query 查询条件 根据metadata属性 * @param previous 上一步查询结果 * @param set DataSet * @return constraints constraints * @throws Exception 异常 */ @Override public LinkedHashMap constraints(DataRuntime runtime, int index, boolean create, LinkedHashMap previous, Constraint query, DataSet set) throws Exception { set.removeColumn("CONSTRAINT_CATALOG"); return super.constraints(runtime, index, create, previous, query, set); } /* ***************************************************************************************************************** * trigger * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * LinkedHashMap triggers(DataRuntime runtime, String random, boolean greedy, Table table, List events) * [命令合成] * List buildQueryTriggersRun(DataRuntime runtime, boolean greedy, Table table, List events) * [结果集封装]
* LinkedHashMap triggers(DataRuntime runtime, int index, boolean create, Table table, LinkedHashMap triggers, DataSet set) ******************************************************************************************************************/ /** * * trigger[调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param greedy 贪婪模式 true:如果不填写catalog或schema则查询全部 false:只在当前catalog和schema中查询 * @param query 查询条件 根据metadata属性 * @return LinkedHashMap * @param Index */ public LinkedHashMap triggers(DataRuntime runtime, String random, boolean greedy, Trigger query) { return super.triggers(runtime, random, greedy, query); } /** * trigger[命令合成]
* 查询表上的 Trigger * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param query 查询条件 根据metadata属性 * @return runs */ public List buildQueryTriggersRun(DataRuntime runtime, boolean greedy, Trigger query) { List events = query.getEvents(); List runs = new ArrayList<>(); Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); ConfigStore configs = run.getConfigs(); builder.append("SELECT * FROM INFORMATION_SCHEMA.TRIGGERS"); configs.and("TRIGGER_SCHEMA", query.getSchemaName()); configs.and(Compare.LIKE_SIMPLE, "EVENT_OBJECT_TABLE", query.getTableName()); configs.in("EVENT_MANIPULATION", events); return runs; } /** * trigger[结果集封装]
* trigger 属性与结果集对应关系 * @return MetadataFieldRefer */ @Override public MetadataFieldRefer initTriggerFieldRefer() { MetadataFieldRefer refer = new MetadataFieldRefer(Trigger.class); refer.map(Trigger.FIELD_NAME, "TRIGGER_NAME"); refer.map(Trigger.FIELD_SCHEMA, "TRIGGER_SCHEMA"); refer.map(Trigger.FIELD_TABLE, "EVENT_OBJECT_TABLE"); refer.map(Trigger.FIELD_EVENT, "EVENT_MANIPULATION"); refer.map(Trigger.FIELD_DEFINITION, "ACTION_STATEMENT"); return refer; } /** * trigger[结果集封装]
* 根据查询结果集构造 Trigger * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条查询SQL 对照 buildQueryConstraintsRun 返回顺序 * @param create 上一步没有查到的,这一步是否需要新创建 * @param query 查询条件 根据metadata属性 * @param previous 上一步查询结果 * @param set 查询结果集 * @return LinkedHashMap * @throws Exception 异常 */ public LinkedHashMap triggers(DataRuntime runtime, int index, boolean create, LinkedHashMap previous, Trigger query, DataSet set) throws Exception { return super.triggers(runtime, index, create, previous, query, set); } /** * trigger[结果集封装]
* 根据查询结果封装trigger对象,只封装catalog,schema,name等基础属性 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 上一步封装结果 * @param query 查询条件 根据metadata属性 * @param row 查询结果集 * @return Trigger */ @Override public T init(DataRuntime runtime, int index, T meta, Trigger query, DataRow row) { meta = super.init(runtime, index, meta, query, row); if(null == meta) { meta = (T)new Trigger(); } boolean each = false; if("ROW".equalsIgnoreCase(row.getString("ACTION_ORIENTATION"))) { each = true; } meta.setEach(each); try{ String[] events = row.getStringNvl("EVENT_MANIPULATION").split(","); String time = row.getString("ACTION_TIMING"); meta.setTime(Trigger.TIME.valueOf(time)); for(String event:events) { meta.addEvent(Trigger.EVENT.valueOf(event)); } }catch (Exception e) { log.error("封装trigger 异常:", e); } return meta; } /** * trigger[结果集封装]
* 根据查询结果封装trigger对象,更多属性 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 上一步封装结果 * @param row 查询结果集 * @return Trigger */ @Override public T detail(DataRuntime runtime, int index, T meta, Trigger query, DataRow row) { if(log.isDebugEnabled()) { log.debug(LogUtil.format("子类(" + this.getClass().getSimpleName() + ")未实现 T detail(DataRuntime runtime, int index, T meta, Trigger query, DataRow row)", 37)); } return meta; } /* ***************************************************************************************************************** * procedure * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * List procedures(DataRuntime runtime, String random, boolean greedy, Catalog catalog, Schema schema, String pattern); * LinkedHashMap procedures(DataRuntime runtime, String random, Catalog catalog, Schema schema, String pattern); * [命令合成] * List buildQueryProceduresRun(DataRuntime runtime, boolean greedy, Catalog catalog, Schema schema, String pattern) ; * [结果集封装]
* List procedures(DataRuntime runtime, int index, boolean create, List procedures, DataSet set) throws Exception; * LinkedHashMap procedures(DataRuntime runtime, int index, boolean create, LinkedHashMap procedures, DataSet set) throws Exception; * List procedures(DataRuntime runtime, boolean create, List procedures, DataSet set) throws Exception; * LinkedHashMap procedures(DataRuntime runtime, boolean create, LinkedHashMap procedures, DataSet set) throws Exception; * [调用入口] * List ddl(DataRuntime runtime, String random, Procedure procedure); * [命令合成] * List buildQueryDdlRun(DataRuntime runtime, Procedure procedure) throws Exception; * [结果集封装]
* List ddl(DataRuntime runtime, int index, Procedure procedure, List ddls, DataSet set); ******************************************************************************************************************/ /** * * procedure[调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param greedy 贪婪模式 true:如果不填写catalog或schema则查询全部 false:只在当前catalog和schema中查询 * @param query 查询条件 根据metadata属性 * @return LinkedHashMap * @param Index */ @Override public List procedures(DataRuntime runtime, String random, boolean greedy, Procedure query) { return super.procedures(runtime, random, greedy, query); } /** * * procedure[调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param query 查询条件 根据metadata属性 * @return LinkedHashMap * @param Index */ @Override public LinkedHashMap procedures(DataRuntime runtime, String random, Procedure query) { return super.procedures(runtime, random, query); } /** * procedure[命令合成]
* 查询表上的 Trigger * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param query 查询条件 根据metadata属性 * @return runs */ @Override public List buildQueryProceduresRun(DataRuntime runtime, boolean greedy, Procedure query) { List runs = new ArrayList<>(); Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); ConfigStore configs = run.getConfigs(); builder.append("SELECT * FROM information_schema.ROUTINES WHERE ROUTINE_TYPE = 'PROCEDURE'"); configs.and("ROUTINE_SCHEMA", query.getSchemaName()); configs.and(Compare.LIKE_SIMPLE,"ROUTINE_NAME", query.getName()); return runs; } /** * procedure[结果集封装]
* Procedure 属性与结果集对应关系 * @return MetadataFieldRefer */ @Override public MetadataFieldRefer initProcedureFieldRefer() { MetadataFieldRefer refer = new MetadataFieldRefer(Procedure.class); refer.map(Procedure.FIELD_NAME, "ROUTINE_NAME"); refer.map(Procedure.FIELD_SCHEMA, "ROUTINE_NAME"); refer.map(Procedure.FIELD_DEFINITION, "ROUTINE_DEFINITION"); return refer; } /** * procedure[结果集封装]
* 根据查询结果集构造 Trigger * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条查询SQL 对照 buildQueryConstraintsRun 返回顺序 * @param create 上一步没有查到的,这一步是否需要新创建 * @param previous 上一步查询结果 * @param set 查询结果集 * @return LinkedHashMap * @throws Exception 异常 */ @Override public LinkedHashMap procedures(DataRuntime runtime, int index, boolean create, LinkedHashMap previous, Procedure query, DataSet set) throws Exception { return super.procedures(runtime, index, create, previous, query, set); } /** * procedure[结果集封装]
* 根据驱动内置接口补充 Procedure * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param create 上一步没有查到的,这一步是否需要新创建 * @param previous 上一步查询结果 * @return List * @throws Exception 异常 */ @Override public List procedures(DataRuntime runtime, boolean create, List previous, Procedure query) throws Exception { return super.procedures(runtime, create, previous, query); } /** * procedure[结果集封装]
* 根据驱动内置接口补充 Procedure * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param create 上一步没有查到的,这一步是否需要新创建 * @param previous 上一步查询结果 * @return LinkedHashMap * @throws Exception 异常 */ @Override public LinkedHashMap procedures(DataRuntime runtime, boolean create, LinkedHashMap previous, Procedure query) throws Exception { return super.procedures(runtime, create, previous, query); } /** * * procedure[调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param procedure Procedure * @return ddl */ @Override public List ddl(DataRuntime runtime, String random, Procedure procedure) { return super.ddl(runtime, random, procedure); } /** * procedure[命令合成]
* 查询存储DDL * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param procedure 存储过程 * @return List */ @Override public List buildQueryDdlRun(DataRuntime runtime, Procedure procedure) throws Exception { List runs = new ArrayList<>(); Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); builder.append("show create procedure "); name(runtime, builder, procedure); return runs; } /** * procedure[结果集封装]
* 查询 Procedure DDL * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条SQL 对照 buildQueryDdlRun 返回顺序 * @param procedure Procedure * @param set 查询结果集 * @return List */ @Override public List ddl(DataRuntime runtime, int index, Procedure procedure, List ddls, DataSet set) { if(null == ddls) { ddls = new ArrayList<>(); } for(DataRow row:set) { ddls.add(row.getString("Create Procedure")); } return ddls; } /* ***************************************************************************************************************** * function * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * List functions(DataRuntime runtime, String random, boolean greedy, Catalog catalog, Schema schema, String pattern); * LinkedHashMap functions(DataRuntime runtime, String random, Catalog catalog, Schema schema, String pattern); * [命令合成] * List buildQueryFunctionsRun(DataRuntime runtime, Catalog catalog, Schema schema, String pattern) ; * [结果集封装]
* List functions(DataRuntime runtime, int index, boolean create, List functions, Catalog catalog, Schema schema, DataSet set) throws Exception; * LinkedHashMap functions(DataRuntime runtime, int index, boolean create, LinkedHashMap functions, Catalog catalog, Schema schema, DataSet set) throws Exception; * List functions(DataRuntime runtime, boolean create, List functions, DataSet set) throws Exception; * LinkedHashMap functions(DataRuntime runtime, boolean create, LinkedHashMap functions, DataSet set) throws Exception; * [调用入口] * List ddl(DataRuntime runtime, String random, Function function); * [命令合成] * List buildQueryDdlRun(DataRuntime runtime, Function function) throws Exception; * [结果集封装]
* List ddl(DataRuntime runtime, int index, Function function, List ddls, DataSet set) ******************************************************************************************************************/ /** * * function[调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param greedy 贪婪模式 true:如果不填写catalog或schema则查询全部 false:只在当前catalog和schema中查询 * @param query 查询条件 根据metadata属性 * @return LinkedHashMap * @param Index */ @Override public List functions(DataRuntime runtime, String random, boolean greedy, Function query) { return super.functions(runtime, random, greedy, query); } /** * * function[调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param query 查询条件 根据metadata属性 * @return LinkedHashMap * @param Index */ @Override public LinkedHashMap functions(DataRuntime runtime, String random, Function query) { return super.functions(runtime, random, query); } /** * function[命令合成]
* 查询表上的 Trigger * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param query 查询条件 根据metadata属性 * @return runs */ @Override public List buildQueryFunctionsRun(DataRuntime runtime, boolean greedy, Function query) { List runs = new ArrayList<>(); Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); ConfigStore configs = run.getConfigs(); builder.append("SELECT * FROM information_schema.ROUTINES WHERE ROUTINE_TYPE = 'FUNCTION'"); configs.and("ROUTINE_SCHEMA", query.getSchemaName()); configs.and(Compare.LIKE_SIMPLE,"ROUTINE_NAME", query.getName()); return runs; } /** * Function[结果集封装]
* Function 属性与结果集对应关系 * @return MetadataFieldRefer */ @Override public MetadataFieldRefer initFunctionFieldRefer() { MetadataFieldRefer refer = new MetadataFieldRefer(Function.class); refer.map(Function.FIELD_NAME, "ROUTINE_NAME"); refer.map(Function.FIELD_SCHEMA, "ROUTINE_SCHEMA"); refer.map(Function.FIELD_CATALOG, ""); refer.map(Function.FIELD_DEFINITION, "ROUTINE_DEFINITION"); return refer; } /** * function[结果集封装]
* 根据查询结果集构造 Trigger * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条查询SQL 对照 buildQueryConstraintsRun 返回顺序 * @param create 上一步没有查到的,这一步是否需要新创建 * @param previous 上一步查询结果 * @param set 查询结果集 * @return LinkedHashMap * @throws Exception 异常 */ @Override public List functions(DataRuntime runtime, int index, boolean create, List previous, Function query, DataSet set) throws Exception { return super.functions(runtime, index, create, previous, query, set); } /** * function[结果集封装]
* 根据查询结果集构造 Trigger * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条查询SQL 对照 buildQueryConstraintsRun 返回顺序 * @param create 上一步没有查到的,这一步是否需要新创建 * @param previous 上一步查询结果 * @param set 查询结果集 * @return LinkedHashMap * @throws Exception 异常 */ @Override public LinkedHashMap functions(DataRuntime runtime, int index, boolean create, LinkedHashMap previous, Function query, DataSet set) throws Exception { return super.functions(runtime, index, create, previous, query, set); } /** * function[结果集封装]
* 根据驱动内置接口补充 Function * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param create 上一步没有查到的,这一步是否需要新创建 * @param previous 上一步查询结果 * @return LinkedHashMap * @throws Exception 异常 */ @Override public List functions(DataRuntime runtime, boolean create, List previous, Function query) throws Exception { return super.functions(runtime, create, previous, query); } /** * * function[调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param meta Function * @return ddl */ @Override public List ddl(DataRuntime runtime, String random, Function meta) { return super.ddl(runtime, random, meta); } /** * function[命令合成]
* 查询函数DDL * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 函数 * @return List */ @Override public List buildQueryDdlRun(DataRuntime runtime, Function meta) throws Exception { List runs = new ArrayList<>(); Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); builder.append("show create function "); name(runtime, builder, meta); return runs; } /** * function[结果集封装]
* 查询 Function DDL * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条SQL 对照 buildQueryDdlRun 返回顺序 * @param function Function * @param set 查询结果集 * @return List */ @Override public List ddl(DataRuntime runtime, int index, Function function, List ddls, DataSet set) { if(null == ddls) { ddls = new ArrayList<>(); } for(DataRow row:set) { ddls.add(row.getString("Create Function")); } return ddls; } /* ***************************************************************************************************************** * sequence * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * List sequences(DataRuntime runtime, String random, boolean greedy, Catalog catalog, Schema schema, String pattern); * LinkedHashMap sequences(DataRuntime runtime, String random, Catalog catalog, Schema schema, String pattern); * [命令合成] * List buildQuerySequencesRun(DataRuntime runtime, Catalog catalog, Schema schema, String pattern) ; * [结果集封装]
* List sequences(DataRuntime runtime, int index, boolean create, List sequences, DataSet set) throws Exception; * LinkedHashMap sequences(DataRuntime runtime, int index, boolean create, LinkedHashMap sequences, DataSet set) throws Exception; * List sequences(DataRuntime runtime, boolean create, List sequences, DataSet set) throws Exception; * LinkedHashMap sequences(DataRuntime runtime, boolean create, LinkedHashMap sequences, DataSet set) throws Exception; * [调用入口] * List ddl(DataRuntime runtime, String random, Sequence sequence); * [命令合成] * List buildQueryDdlRun(DataRuntime runtime, Sequence sequence) throws Exception; * [结果集封装]
* List ddl(DataRuntime runtime, int index, Sequence sequence, List ddls, DataSet set) ******************************************************************************************************************/ /** * * sequence[调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param greedy 贪婪模式 true:如果不填写catalog或schema则查询全部 false:只在当前catalog和schema中查询 * @param query 查询条件 根据metadata属性 * @return LinkedHashMap * @param Index */ @Override public List sequences(DataRuntime runtime, String random, boolean greedy, Sequence query) { return super.sequences(runtime, random, greedy, query); } /** * * sequence[调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param query 查询条件 根据metadata属性 * @return LinkedHashMap * @param Index */ @Override public LinkedHashMap sequences(DataRuntime runtime, String random, Sequence query) { return super.sequences(runtime, random, query); } /** * sequence[命令合成]
* 查询表上的 Trigger * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param query 查询条件 根据metadata属性 * @return runs */ @Override public List buildQuerySequencesRun(DataRuntime runtime, boolean greedy, Sequence query) { return super.buildQuerySequencesRun(runtime, greedy, query); } /** * sequence[结果集封装]
* 根据查询结果集构造 Trigger * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条查询SQL 对照 buildQueryConstraintsRun 返回顺序 * @param create 上一步没有查到的,这一步是否需要新创建 * @param previous 上一步查询结果 * @param set 查询结果集 * @return LinkedHashMap * @throws Exception 异常 */ @Override public List sequences(DataRuntime runtime, int index, boolean create, List previous, Sequence query, DataSet set) throws Exception { return super.sequences(runtime, index, create, previous, query, set); } /** * sequence[结果集封装]
* 根据查询结果集构造 Trigger * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条查询SQL 对照 buildQueryConstraintsRun 返回顺序 * @param create 上一步没有查到的,这一步是否需要新创建 * @param previous 上一步查询结果 * @param set 查询结果集 * @return LinkedHashMap * @throws Exception 异常 */ @Override public LinkedHashMap sequences(DataRuntime runtime, int index, boolean create, LinkedHashMap previous, Sequence query, DataSet set) throws Exception { return super.sequences(runtime, index, create, previous, query, set); } /** * sequence[结果集封装]
* 根据驱动内置接口补充 Sequence * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param create 上一步没有查到的,这一步是否需要新创建 * @param previous 上一步查询结果 * @return LinkedHashMap * @throws Exception 异常 */ @Override public List sequences(DataRuntime runtime, boolean create, List previous, Sequence query) throws Exception { return super.sequences(runtime, create, previous, query); } /** * * sequence[调用入口]
* @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param meta Sequence * @return ddl */ @Override public List ddl(DataRuntime runtime, String random, Sequence meta) { return super.ddl(runtime, random, meta); } /** * sequence[命令合成]
* 查询序列DDL * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 序列 * @return List */ @Override public List buildQueryDdlRun(DataRuntime runtime, Sequence meta) throws Exception { return super.buildQueryDdlRun(runtime, meta); } /** * sequence[结果集封装]
* 查询 Sequence DDL * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条SQL 对照 buildQueryDdlRun 返回顺序 * @param sequence Sequence * @param set 查询结果集 * @return List */ @Override public List ddl(DataRuntime runtime, int index, Sequence sequence, List ddls, DataSet set) { return super.ddl(runtime, index, sequence, ddls, set); } /* ***************************************************************************************************************** * common * ---------------------------------------------------------------------------------------------------------------- */ /** * * 根据 catalog, schema, name检测tables集合中是否存在 * @param metas metas * @param catalog 对于MySQL, 则对应相应的数据库, 对于Oracle来说, 则是对应相应的数据库实例, 可以不填, 也可以直接使用Connection的实例对象中的getCatalog()方法返回的值填充; * @param schema 可以理解为数据库的登录名, 而对于Oracle也可以理解成对该数据库操作的所有者的登录名。对于Oracle要特别注意, 其登陆名必须是大写, 不然的话是无法获取到相应的数据, 而MySQL则不做强制要求。 * @param name name * @return 如果存在则返回Table 不存在则返回null * @param Table */ @Override public T search(List metas, Catalog catalog, Schema schema, String name) { return super.search(metas, catalog, schema, name); } /** * * 根据 catalog, name检测schemas集合中是否存在 * @param schemas schemas * @param catalog 对于MySQL, 则对应相应的数据库, 对于Oracle来说, 则是对应相应的数据库实例, 可以不填, 也可以直接使用Connection的实例对象中的getCatalog()方法返回的值填充; * @param name name * @return 如果存在则返回 Schema 不存在则返回null * @param Table */ @Override public T schema(List schemas, Catalog catalog, String name) { return super.schema(schemas, catalog, name); } /** * * 根据 name检测catalogs集合中是否存在 * @param catalogs catalogs * @param name name * @return 如果存在则返回 Catalog 不存在则返回null * @param Table */ @Override public T catalog(List catalogs, String name) { return super.catalog(catalogs, name); } /** * * 根据 name检测databases集合中是否存在 * @param databases databases * @param name name * @return 如果存在则返回 Database 不存在则返回null * @param Table */ @Override public T database(List databases, String name) { return super.database(databases, name); } /* ***************************************************************************************************************** * * DDL * * ================================================================================================================= * database : 数据库 * table : 表 * master table : 主表 * partition table : 分区表 * column : 列 * tag : 标签 * primary key : 主键 * foreign key : 外键 * index : 索引 * constraint : 约束 * trigger : 触发器 * procedure : 存储过程 * function : 函数 ******************************************************************************************************************/ /** * 是否支持DDL合并 * @return boolean */ public boolean slice() { return true; } /** * ddl [执行命令] * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param meta Metadata(表,列等) * @param action 执行命令 * @param run 最终待执行的命令和参数(如JDBC环境中的SQL) * @return boolean */ @Override public boolean execute(DataRuntime runtime, String random, Metadata meta, ACTION.DDL action, Run run) { return super.execute(runtime, random, meta, action, run); } /* ***************************************************************************************************************** * catalog * ----------------------------------------------------------------------------------------------------------------- * boolean create(Catalog catalog) throws Exception * boolean alter(Catalog catalog) throws Exception * boolean drop(Catalog catalog) throws Exception * boolean rename(Catalog origin, String name) throws Exception ******************************************************************************************************************/ /** * catalog[调用入口]
* 创建Catalog,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta Catalog * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean create(DataRuntime runtime, Catalog meta) throws Exception { return super.create(runtime, meta); } /** * catalog[调用入口]
* 修改Catalog,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta Catalog * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean alter(DataRuntime runtime, Catalog meta) throws Exception { return super.alter(runtime, meta); } /** * catalog[调用入口]
* 删除Catalog,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta Catalog * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean drop(DataRuntime runtime, Catalog meta) throws Exception { return super.drop(runtime, meta); } /** * catalog[调用入口]
* 重命名Catalog,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param origin 原Catalog * @param name 新名称 * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean rename(DataRuntime runtime, Catalog origin, String name) throws Exception { return super.rename(runtime, origin, name); } /** * catalog[命令合成]
* 创建Catalog
* 其中1.x三选一 不要重复 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta Catalog * @return sql * @throws Exception 异常 */ @Override public List buildCreateRun(DataRuntime runtime, Catalog meta) throws Exception { return super.buildCreateRun(runtime, meta); } /** * catalog[命令合成]
* 修改Catalog * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta Catalog * @return sql * @throws Exception 异常 */ @Override public List buildAlterRun(DataRuntime runtime, Catalog meta) throws Exception { return super.buildAlterRun(runtime, meta); } /** * catalog[命令合成]
* 重命名 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta Catalog * @return sql * @throws Exception 异常 */ @Override public List buildRenameRun(DataRuntime runtime, Catalog meta) throws Exception { return super.buildRenameRun(runtime, meta); } /** * catalog[命令合成]
* 删除Catalog * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta Catalog * @return sql * @throws Exception 异常 */ @Override public List buildDropRun(DataRuntime runtime, Catalog meta) throws Exception { return super.buildDropRun(runtime, meta); } /** * catalog[命令合成-子流程]
* 创建Catalog完成后追加Catalog备注,创建过程能添加备注的不需要实现与comment(DataRuntime runtime, StringBuilder builder, Catalog meta)二选一实现 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta Catalog * @return sql * @throws Exception 异常 */ @Override public List buildAppendCommentRun(DataRuntime runtime, Catalog meta) throws Exception { return super.buildAppendCommentRun(runtime, meta); } /** * catalog[命令合成-子流程]
* 创建Catalog完成后追加列备注,创建过程能添加备注的不需要实现与comment(DataRuntime runtime, StringBuilder builder, Column meta)二选一实现 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta Catalog * @return sql * @throws Exception 异常 */ @Override public List buildAppendColumnCommentRun(DataRuntime runtime, Catalog meta) throws Exception { return super.buildAppendColumnCommentRun(runtime, meta); } /** * catalog[命令合成-子流程]
* 修改备注 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param catalog Catalog * @return sql * @throws Exception 异常 */ @Override public List buildChangeCommentRun(DataRuntime runtime, Catalog catalog) throws Exception { return super.buildChangeCommentRun(runtime, catalog); } /** * catalog[命令合成-子流程]
* 添加备注(部分数据库需要区分添加还是修改) * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param catalog Catalog * @return sql * @throws Exception 异常 */ @Override public List buildAddCommentRun(DataRuntime runtime, Catalog catalog) throws Exception { return super.buildAddCommentRun(runtime, catalog); } /** * catalog[命令合成-子流程]
* 创建或删除Catalog之前 检测Catalog是否存在 * IF NOT EXISTS * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param exists exists * @return StringBuilder */ @Override public StringBuilder checkCatalogExists(DataRuntime runtime, StringBuilder builder, boolean exists) { return super.checkCatalogExists(runtime, builder, exists); } /** * catalog[命令合成-子流程]
* 创建Catalog engine * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param meta Catalog * @return StringBuilder */ @Override public StringBuilder engine(DataRuntime runtime, StringBuilder builder, Catalog meta) { return super.engine(runtime, builder, meta); } /** * catalog[命令合成-子流程]
* 编码 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param meta Catalog * @return StringBuilder */ @Override public StringBuilder charset(DataRuntime runtime, StringBuilder builder, Catalog meta) { return super.charset(runtime, builder, meta); } /** * catalog[命令合成-子流程]
* Catalog备注 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param meta Catalog * @return StringBuilder */ @Override public StringBuilder comment(DataRuntime runtime, StringBuilder builder, Catalog meta) { return super.comment(runtime, builder, meta); } /** * catalog[命令合成-子流程]
* 扩展属性 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param meta Catalog * @return StringBuilder */ @Override public StringBuilder property(DataRuntime runtime, StringBuilder builder, Catalog meta) { return super.property(runtime, builder, meta); } /* ***************************************************************************************************************** * schema * ----------------------------------------------------------------------------------------------------------------- * boolean create(Schema schema) throws Exception * boolean alter(Schema schema) throws Exception * boolean drop(Schema schema) throws Exception * boolean rename(Schema origin, String name) throws Exception ******************************************************************************************************************/ /** * schema[调用入口]
* 创建Schema,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta Schema * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean create(DataRuntime runtime, Schema meta) throws Exception { return super.create(runtime, meta); } /** * schema[调用入口]
* 修改Schema,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta Schema * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean alter(DataRuntime runtime, Schema meta) throws Exception { return super.alter(runtime, meta); } /** * schema[调用入口]
* 删除Schema,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta Schema * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean drop(DataRuntime runtime, Schema meta) throws Exception { return super.drop(runtime, meta); } /** * schema[调用入口]
* 重命名Schema,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param origin 原Schema * @param name 新名称 * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean rename(DataRuntime runtime, Schema origin, String name) throws Exception { return super.rename(runtime, origin, name); } /** * schema[命令合成]
* 创建Schema
* 其中1.x三选一 不要重复 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta Schema * @return sql * @throws Exception 异常 */ @Override public List buildCreateRun(DataRuntime runtime, Schema meta) throws Exception { return super.buildCreateRun(runtime, meta); } /** * schema[命令合成]
* 修改Schema * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta Schema * @return sql * @throws Exception 异常 */ @Override public List buildAlterRun(DataRuntime runtime, Schema meta) throws Exception { return super.buildAlterRun(runtime, meta); } /** * schema[命令合成]
* 重命名 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta Schema * @return sql * @throws Exception 异常 */ @Override public List buildRenameRun(DataRuntime runtime, Schema meta) throws Exception { return super.buildRenameRun(runtime, meta); } /** * schema[命令合成]
* 删除Schema * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta Schema * @return sql * @throws Exception 异常 */ @Override public List buildDropRun(DataRuntime runtime, Schema meta) throws Exception { return super.buildDropRun(runtime, meta); } /** * schema[命令合成-子流程]
* 创建Schema完成后追加Schema备注,创建过程能添加备注的不需要实现与comment(DataRuntime runtime, StringBuilder builder, Schema meta)二选一实现 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta Schema * @return sql * @throws Exception 异常 */ @Override public List buildAppendCommentRun(DataRuntime runtime, Schema meta) throws Exception { return super.buildAppendCommentRun(runtime, meta); } /** * schema[命令合成-子流程]
* 创建Schema完成后追加列备注,创建过程能添加备注的不需要实现与comment(DataRuntime runtime, StringBuilder builder, Column meta)二选一实现 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta Schema * @return sql * @throws Exception 异常 */ @Override public List buildAppendColumnCommentRun(DataRuntime runtime, Schema meta) throws Exception { return super.buildAppendColumnCommentRun(runtime, meta); } /** * schema[命令合成-子流程]
* 修改备注 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param schema Schema * @return sql * @throws Exception 异常 */ @Override public List buildChangeCommentRun(DataRuntime runtime, Schema schema) throws Exception { return super.buildChangeCommentRun(runtime, schema); } /** * schema[命令合成-子流程]
* 添加备注(部分数据库需要区分添加还是修改) * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param schema Schema * @return sql * @throws Exception 异常 */ @Override public List buildAddCommentRun(DataRuntime runtime, Schema schema) throws Exception { return super.buildAddCommentRun(runtime, schema); } /** * schema[命令合成-子流程]
* 创建或删除Schema之前 检测Schema是否存在 * IF NOT EXISTS * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param exists exists * @return StringBuilder */ @Override public StringBuilder checkSchemaExists(DataRuntime runtime, StringBuilder builder, boolean exists) { return super.checkSchemaExists(runtime, builder, exists); } /** * schema[命令合成-子流程]
* 创建Schema engine * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param meta Schema * @return StringBuilder */ @Override public StringBuilder engine(DataRuntime runtime, StringBuilder builder, Schema meta) { return super.engine(runtime, builder, meta); } /** * schema[命令合成-子流程]
* 编码 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param meta Schema * @return StringBuilder */ @Override public StringBuilder charset(DataRuntime runtime, StringBuilder builder, Schema meta) { return super.charset(runtime, builder, meta); } /** * schema[命令合成-子流程]
* Schema备注 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param meta Schema * @return StringBuilder */ @Override public StringBuilder comment(DataRuntime runtime, StringBuilder builder, Schema meta) { return super.comment(runtime, builder, meta); } /** * schema[命令合成-子流程]
* 扩展属性 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param meta Schema * @return StringBuilder */ @Override public StringBuilder property(DataRuntime runtime, StringBuilder builder, Schema meta) { return super.property(runtime, builder, meta); } /* ***************************************************************************************************************** * table * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * boolean create(DataRuntime runtime, Table meta) * boolean alter(DataRuntime runtime, Table meta) * boolean drop(DataRuntime runtime, Table meta) * boolean rename(DataRuntime runtime, Table origin, String name) * [命令合成] * List buildCreateRun(DataRuntime runtime, Table meta) * List buildAlterRun(DataRuntime runtime, Table meta) * List buildAlterRun(DataRuntime runtime, Table meta, Collection columns) * List buildRenameRun(DataRuntime runtime, Table meta) * List buildDropRun(DataRuntime runtime, Table meta) * [命令合成-子流程] * List buildAppendCommentRun(DataRuntime runtime, Table table) * List buildChangeCommentRun(DataRuntime runtime, Table table) * StringBuilder checkTableExists(DataRuntime runtime, StringBuilder builder, boolean exists) * StringBuilder primary(DataRuntime runtime, StringBuilder builder, Table table) * time runtime, StringBuilder builder, Table table) * StringBuilder comment(DataRuntime runtime, StringBuilder builder, Table table) * StringBuilder partitionBy(DataRuntime runtime, StringBuilder builder, Table table) * StringBuilder partitionOf(DataRuntime runtime, StringBuilder builder, Table table) ******************************************************************************************************************/ /** * table[调用入口]
* 创建表,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 表 * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean create(DataRuntime runtime, Table meta) throws Exception { return super.create(runtime, meta); } /** * table[调用入口]
* 修改表,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 表 * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean alter(DataRuntime runtime, Table meta) throws Exception { if(meta.isSort()) { sort(meta.getColumns()); } Table update = (Table)meta.getUpdate(); if(null != update) { if(update.isSort()) { sort(update.getColumns()); } } return super.alter(runtime, meta); } protected void sort(LinkedHashMap columns) { String prefix = null; for(Column column:columns.values()) { if(null == prefix) { column.setPosition(0); }else{ column.setAfter(prefix); } if(!column.isDrop()) { prefix = column.getName(); } } } /** * table[调用入口]
* 删除表,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 表 * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean drop(DataRuntime runtime, Table meta) throws Exception { return super.drop(runtime, meta); } /** * table[调用入口]
* 重命名表,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param origin 原表 * @param name 新名称 * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean rename(DataRuntime runtime, Table origin, String name) throws Exception { return super.rename(runtime, origin, name); } /** * table[命令合成-子流程]
* 部分数据库在创建主表时用主表关键字(默认),部分数据库普通表主表子表都用table,部分数据库用collection、timeseries等 * @param meta 表 * @return String */ @Override public String keyword(Metadata meta) { if(meta instanceof Table) { return "TABLE"; } return super.keyword(meta); } /** * table[命令合成]
* 创建表
* 关于创建主键的几个环节
* 1.1.定义列时 标识 primary(DataRuntime runtime, StringBuilder builder, Column column)
* 1.2.定义表时 标识 primary(DataRuntime runtime, StringBuilder builder, Table table)
* 1.3.定义完表DDL后,单独创建 primary(DataRuntime runtime, PrimaryKey primary)根据三选一情况调用buildCreateRun
* 2.单独创建 buildCreateRun(DataRuntime runtime, PrimaryKey primary)
* 其中1.x三选一 不要重复 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 表 * @return runs * @throws Exception Exception */ @Override public List buildCreateRun(DataRuntime runtime, Table meta) throws Exception { List runs = new ArrayList<>(); Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); builder.append("CREATE ").append(keyword(meta)).append(" "); checkTableExists(runtime, builder, false); name(runtime, builder, meta); //列,索引 body(runtime, builder, meta); //索引 indexes(runtime, builder, meta); //继承表 inherit(runtime, builder, meta); //引擎 engine(runtime, builder, meta); //编码方式 charset(runtime, builder, meta); //keys type keys(runtime, builder, meta); //注释 comment(runtime, builder, meta); //分表 partitionBy(runtime, builder, meta); partitionFor(runtime, builder, meta); //分桶方式 distribution(runtime, builder, meta); //物化视图 materialize(runtime, builder, meta); //扩展属性 property(runtime, builder, meta); runs.addAll(buildAppendCommentRun(runtime, meta)); runs.addAll(buildAppendColumnCommentRun(runtime, meta)); runs.addAll(buildAppendPrimaryRun(runtime, meta)); runs.addAll(buildAppendIndexRun(runtime, meta)); return runs; } /** * table[命令合成]
* 修改表 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 表 * @return sql * @throws Exception 异常 */ @Override public List buildAlterRun(DataRuntime runtime, Table meta) throws Exception { return super.buildAlterRun(runtime, meta); } /** * table[命令合成]
* 修改列 * 有可能生成多条SQL,根据数据库类型优先合并成一条执行 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 表 * @param columns 列 * @return List */ @Override public List buildAlterRun(DataRuntime runtime, Table meta, Collection columns, boolean slice) throws Exception { return super.buildAlterRun(runtime, meta, columns, slice); } /** * table[命令合成]
* 重命名 * 子类实现 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 表 * @return sql * @throws Exception 异常 */ @Override public List buildRenameRun(DataRuntime runtime, Table meta) throws Exception { List runs = new ArrayList<>(); Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); builder.append("RENAME TABLE "); name(runtime, builder, meta); builder.append(" TO "); name(runtime, builder, meta.getUpdate()); return runs; } /** * table[命令合成]
* 删除表 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 表 * @return sql * @throws Exception 异常 */ @Override public List buildDropRun(DataRuntime runtime, Table meta) throws Exception { return super.buildDropRun(runtime, meta); } /** * table[命令合成-子流程]
* 创建表完成后追加表备注,创建过程能添加备注的不需要实现与comment(DataRuntime runtime, StringBuilder builder, Table meta)二选一实现 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 表 * @return sql * @throws Exception 异常 */ @Override public List buildAppendCommentRun(DataRuntime runtime, Table meta) throws Exception { List runs = new ArrayList<>(); /*String comment = meta.getComment(); if(BasicUtil.isEmpty(comment)) { return runs; } Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); builder.append("ALTER TABLE "); name(runtime, builder, meta); builder.append(" COMMENT '").append(comment).append("'");*/ return runs; } /** * table[命令合成-子流程]
* 创建表完成后追加列备注,创建过程能添加备注的不需要实现与comment(DataRuntime runtime, StringBuilder builder, Column meta)二选一实现 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 表 * @return sql * @throws Exception 异常 */ @Override public List buildAppendColumnCommentRun(DataRuntime runtime, Table meta) throws Exception { return super.buildAppendColumnCommentRun(runtime, meta); } /** * table[命令合成-子流程]
* 修改备注 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 表 * @return sql * @throws Exception 异常 */ @Override public List buildChangeCommentRun(DataRuntime runtime, Table meta) throws Exception { List runs = new ArrayList<>(); String comment = meta.getComment(); if(BasicUtil.isEmpty(comment)) { //return runs; comment = ""; } Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); builder.append("ALTER TABLE "); name(runtime, builder, meta); builder.append(" COMMENT '").append(comment).append("'"); return runs; } /** * table[命令合成-子流程]
* 创建或删除表之前 检测表是否存在 * IF NOT EXISTS * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param exists exists * @return StringBuilder */ @Override public StringBuilder checkTableExists(DataRuntime runtime, StringBuilder builder, boolean exists) { return super.checkTableExists(runtime, builder, exists); } /** * table[命令合成-子流程]
* 检测表主键(在没有显式设置主键时根据其他条件判断如自增),同时根据主键对象给相关列设置主键标识 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param table 表 */ @Override public void checkPrimary(DataRuntime runtime, Table table) { super.checkPrimary(runtime, table); } /** * table[命令合成-子流程]
* 定义表的主键标识,在创建表的DDL结尾部分(注意不要跟列定义中的主键重复) * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param meta 表 * @return StringBuilder */ @Override public StringBuilder primary(DataRuntime runtime, StringBuilder builder, Table meta) { PrimaryKey primary = meta.getPrimaryKey(); LinkedHashMap pks = null; if(null != primary) { pks = primary.getColumns(); }else{ pks = meta.primarys(); } if(!pks.isEmpty()) {//单列多列主键 都在这里实现,因为有其他属性需要设置 builder.append(",PRIMARY KEY ("); boolean first = true; Column.sort(primary.getPositions(), pks); for(Column pk:pks.values()) { if(!first) { builder.append(", "); } first = false; delimiter(builder, pk.getName()); String order = pk.getOrder(); if(BasicUtil.isNotEmpty(order)) { builder.append(" ").append(order); } } builder.append(")"); String type = primary.getType(); if(BasicUtil.isNotEmpty(type)) { builder.append(" USING ").append(type); } } return builder; } /** * table[命令合成-子流程]
* 编码 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param meta 表 * @return StringBuilder */ @Override public StringBuilder charset(DataRuntime runtime, StringBuilder builder, Table meta) { String charset = meta.getCharset(); String collate = meta.getCollate(); if(BasicUtil.isNotEmpty(charset)) { builder.append(" CHARSET = ").append(charset); } if(BasicUtil.isNotEmpty(collate)) { builder.append(" COLLATE = ").append(collate); } return builder; } /** * table[命令合成-子流程]
* 备注 创建表的完整DDL拼接COMMENT部分,与buildAppendCommentRun二选一实现 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param meta 表 * @return StringBuilder */ @Override public StringBuilder comment(DataRuntime runtime, StringBuilder builder, Table meta) { if(null != meta) { String comment = meta.getComment(); if(BasicUtil.isNotEmpty(comment)) { builder.append("\nCOMMENT '").append(comment).append("'"); } } return builder; } /** * table[命令合成-子流程]
* 主表设置分区依据(根据哪几列分区) * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param meta 表 * @return StringBuilder * @throws Exception 异常 */ @Override public StringBuilder partitionBy(DataRuntime runtime, StringBuilder builder, Table meta) throws Exception { // PARTITION BY RANGE (code); #根据code值分区 Table.Partition partition = meta.getPartition(); if(null == partition) { return builder; } builder.append("\nPARTITION BY ").append(partition.getType()).append("("); LinkedHashMap columns = partition.getColumns(); delimiter(builder, Column.names(columns)); builder.append(")"); return builder; } /** * table[命令合成-子流程]
* 子表执行分区依据(相关主表及分区值) * 如CREATE TABLE hr_user_fi PARTITION OF hr_user FOR VALUES IN ('FI') * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param meta 表 * @return StringBuilder * @throws Exception 异常 */ @Override public StringBuilder partitionOf(DataRuntime runtime, StringBuilder builder, Table meta) throws Exception { return super.partitionOf(runtime, builder, meta); } /** * table[命令合成-子流程]
* 子表执行分区依据(分区依据值)如CREATE TABLE hr_user_fi PARTITION OF hr_user FOR VALUES IN ('FI') * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param meta 表 * @return StringBuilder * @throws Exception 异常 */ @Override public StringBuilder partitionFor(DataRuntime runtime, StringBuilder builder, Table meta) throws Exception { Table.Partition partition = meta.getPartition(); if(null == partition) { return builder; } Table.Partition.TYPE type = partition.getType(); if(null == type) { return builder; } if(type == Table.Partition.TYPE.HASH) { builder.append(" PARTITIONS ").append(partition.getModulus()); return builder; } List slices = partition.getSlices(); if(null != slices && !slices.isEmpty()) { builder.append("(\n"); boolean sfirst = true; for(Table.Partition.Slice slice:slices) { builder.append("\n\t"); if(!sfirst) { builder.append(", "); } sfirst = false; Object max = slice.getMax(); List values = slice.getValues(); LinkedHashMap less = slice.getLess(); int interval = slice.getInterval(); String unit = slice.getUnit(); if(type == Table.Partition.TYPE.RANGE) { LinkedHashMap columns = partition.getColumns(); /*PARTITION BY RANGE(col1[, col2, ...]) ( PARTITION partition_name1 VALUES LESS THAN MAXVALUE|("value1", "value2", ...), PARTITION partition_name2 VALUES LESS THAN MAXVALUE|("value1", "value2", ...) )*/ builder.append("PARTITION ").append(slice.getName()).append(" VALUES LESS THAN "); builder.append("("); boolean lfirst = true; for (Column column : columns.values()) { if (!lfirst) { builder.append(", "); } lfirst = false; Object v = less.get(column.getName().toUpperCase()); builder.append(write(runtime, null, v, false, false)); } builder.append(")"); }else if(type == Table.Partition.TYPE.LIST) { /* PARTITION BY List(`address` ) ( PARTITION `p_city1` VALUES IN ("浦东","闵行"), PARTITION `p_city2` VALUES IN ("海淀","昌平"), PARTITION `p_city3` VALUES IN ("太原","忻州") */ builder.append("PARTITION ").append(slice.getName()).append(" VALUES IN("); boolean vfirst = true; for(Object value:values) { if(!vfirst) { builder.append(", "); } vfirst = false; builder.append(write(runtime, null, value, false, false)); } builder.append(")"); } } builder.append("\n)"); } return builder; } /* ***************************************************************************************************************** * view * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * boolean create(DataRuntime runtime, View view) throws Exception; * boolean alter(DataRuntime runtime, View view) throws Exception; * boolean drop(DataRuntime runtime, View view) throws Exception; * boolean rename(DataRuntime runtime, View origin, String name) throws Exception; * [命令合成] * List buildCreateRun(DataRuntime runtime, View view) throws Exception; * List buildAlterRun(DataRuntime runtime, View view) throws Exception; * List buildRenameRun(DataRuntime runtime, View view) throws Exception; * List buildDropRun(DataRuntime runtime, View view) throws Exception; * [命令合成-子流程] * List buildAppendCommentRun(DataRuntime runtime, View view) throws Exception; * List buildChangeCommentRun(DataRuntime runtime, View view) throws Exception; * StringBuilder checkViewExists(DataRuntime runtime, StringBuilder builder, boolean exists); * StringBuilder comment(DataRuntime runtime, StringBuilder builder, View view); ******************************************************************************************************************/ /** * view[调用入口]
* 创建视图,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 视图 * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean create(DataRuntime runtime, View meta) throws Exception { return super.create(runtime, meta); } /** * view[调用入口]
* 修改视图,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 视图 * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean alter(DataRuntime runtime, View meta) throws Exception { return super.alter(runtime, meta); } /** * view[调用入口]
* 删除视图,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 视图 * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean drop(DataRuntime runtime, View meta) throws Exception { return super.drop(runtime, meta); } /** * view[调用入口]
* 重命名视图,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param origin 视图 * @param name 新名称 * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean rename(DataRuntime runtime, View origin, String name) throws Exception { return super.rename(runtime, origin, name); } /** * view[命令合成]
* 创建视图 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 视图 * @return Run * @throws Exception 异常 */ @Override public List buildCreateRun(DataRuntime runtime, View meta) throws Exception { List runs = new ArrayList<>(); Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); builder.append("CREATE OR REPLACE VIEW "); name(runtime, builder, meta); builder.append(" AS \n").append(meta.getDefinition()); runs.addAll(buildAppendCommentRun(runtime, meta)); return runs; } /** * view[命令合成]
* 修改视图 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 视图 * @return sql * @throws Exception 异常 */ @Override public List buildAlterRun(DataRuntime runtime, View meta) throws Exception { return super.buildAlterRun(runtime, meta); } /** * view[命令合成]
* 重命名 * 一般不直接调用,如果需要由buildAlterRun内部统一调用 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 视图 * @return sql * @throws Exception 异常 */ @Override public List buildRenameRun(DataRuntime runtime, View meta) throws Exception { return super.buildRenameRun(runtime, meta); } /** * view[命令合成]
* 删除视图 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 视图 * @return sql * @throws Exception 异常 */ @Override public List buildDropRun(DataRuntime runtime, View meta) throws Exception { return super.buildDropRun(runtime, meta); } /** * view[命令合成-子流程]
* 添加视图备注(视图创建完成后调用,创建过程能添加备注的不需要实现) * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 视图 * @return sql * @throws Exception 异常 */ @Override public List buildAppendCommentRun(DataRuntime runtime, View meta) throws Exception { return super.buildAppendCommentRun(runtime, meta); } /** * view[命令合成-子流程]
* 修改备注 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 视图 * @return sql * @throws Exception 异常 */ @Override public List buildChangeCommentRun(DataRuntime runtime, View meta) throws Exception { return super.buildChangeCommentRun(runtime, meta); } /** * view[命令合成-子流程]
* 创建或删除视图之前 检测视图是否存在 * IF NOT EXISTS * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param exists exists * @return StringBuilder */ @Override public StringBuilder checkViewExists(DataRuntime runtime, StringBuilder builder, boolean exists) { return super.checkViewExists(runtime, builder, exists); } /** * view[命令合成-子流程]
* 视图备注 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param meta 视图 * @return StringBuilder */ @Override public StringBuilder comment(DataRuntime runtime, StringBuilder builder, View meta) { return super.comment(runtime, builder, meta); } /* ***************************************************************************************************************** * MasterTable * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * boolean create(DataRuntime runtime, MasterTable meta) * boolean alter(DataRuntime runtime, MasterTable meta) * boolean drop(DataRuntime runtime, MasterTable meta) * boolean rename(DataRuntime runtime, MasterTable origin, String name) * [命令合成] * List buildCreateRun(DataRuntime runtime, MasterTable table) * List buildDropRun(DataRuntime runtime, MasterTable table) * [命令合成-子流程] * List buildAlterRun(DataRuntime runtime, MasterTable table) * List buildRenameRun(DataRuntime runtime, MasterTable table) * List buildAppendCommentRun(DataRuntime runtime, MasterTable table) * List buildChangeCommentRun(DataRuntime runtime, MasterTable table) ******************************************************************************************************************/ /** * master table[调用入口]
* 创建主表,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 主表 * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean create(DataRuntime runtime, MasterTable meta) throws Exception { return super.create(runtime, meta); } /** * master table[调用入口]
* 修改主表,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 主表 * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean alter(DataRuntime runtime, MasterTable meta) throws Exception { return super.alter(runtime, meta); } /** * master table[调用入口]
* 删除主表,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 主表 * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean drop(DataRuntime runtime, MasterTable meta) throws Exception { return super.drop(runtime, meta); } /** * master table[调用入口]
* 重命名主表,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param origin 原表 * @param name 新名称 * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean rename(DataRuntime runtime, MasterTable origin, String name) throws Exception { return super.rename(runtime, origin, name); } /** * master table[命令合成]
* 创建主表 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 表 * @return sql * @throws Exception 异常 */ @Override public List buildCreateRun(DataRuntime runtime, MasterTable meta) throws Exception { return super.buildCreateRun(runtime, meta); } /** * master table[命令合成]
* 删除主表 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 表 * @return sql * @throws Exception 异常 */ @Override public List buildDropRun(DataRuntime runtime, MasterTable meta) throws Exception { return super.buildDropRun(runtime, meta); } /** * master table[命令合成-子流程]
* 修改主表 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 表 * @return sql * @throws Exception 异常 */ @Override public List buildAlterRun(DataRuntime runtime, MasterTable meta) throws Exception { return super.buildAlterRun(runtime, meta); } /** * master table[命令合成-子流程]
* 主表重命名 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 表 * @return sql * @throws Exception 异常 */ @Override public List buildRenameRun(DataRuntime runtime, MasterTable meta) throws Exception { return super.buildRenameRun(runtime, meta); } /** * master table[命令合成-子流程]
* 创建表完成后追加表备注,创建过程能添加备注的不需要实现与comment(DataRuntime runtime, StringBuilder builder, Table meta)二选一实现 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 表 * @return sql * @throws Exception 异常 */ @Override public List buildAppendCommentRun(DataRuntime runtime, MasterTable meta) throws Exception { return super.buildAppendCommentRun(runtime, meta); } /** * master table[命令合成-子流程]
* 修改主表备注 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 表 * @return sql * @throws Exception 异常 */ @Override public List buildChangeCommentRun(DataRuntime runtime, MasterTable meta) throws Exception { return super.buildChangeCommentRun(runtime, meta); } /* ***************************************************************************************************************** * partition table * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * boolean create(DataRuntime runtime, PartitionTable meta) throws Exception; * boolean alter(DataRuntime runtime, PartitionTable meta) throws Exception; * boolean drop(DataRuntime runtime, PartitionTable meta) throws Exception; * boolean rename(DataRuntime runtime, PartitionTable origin, String name) throws Exception; * [命令合成] * List buildCreateRun(DataRuntime runtime, PartitionTable table) throws Exception; * List buildAppendCommentRun(DataRuntime runtime, PartitionTable table) throws Exception; * List buildAlterRun(DataRuntime runtime, PartitionTable table) throws Exception; * List buildDropRun(DataRuntime runtime, PartitionTable table) throws Exception; * List buildRenameRun(DataRuntime runtime, PartitionTable table) throws Exception; * [命令合成-子流程] * List buildChangeCommentRun(DataRuntime runtime, PartitionTable table) throws Exception; * ******************************************************************************************************************/ /** * partition table[调用入口]
* 创建分区表,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 表 * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean create(DataRuntime runtime, PartitionTable meta) throws Exception { return super.create(runtime, meta); } /** * partition table[调用入口]
* 修改分区表,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 表 * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean alter(DataRuntime runtime, PartitionTable meta) throws Exception { return super.alter(runtime, meta); } /** * partition table[调用入口]
* 删除分区表,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 表 * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean drop(DataRuntime runtime, PartitionTable meta) throws Exception { return super.drop(runtime, meta); } /** * partition table[调用入口]
* 创建分区表,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param origin 原表 * @param name 新名称 * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean rename(DataRuntime runtime, PartitionTable origin, String name) throws Exception { return super.rename(runtime, origin, name); } /** * partition table[命令合成]
* 创建分区表 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 表 * @return sql * @throws Exception 异常 */ @Override public List buildCreateRun(DataRuntime runtime, PartitionTable meta) throws Exception { return super.buildCreateRun(runtime, meta); } /** * partition table[命令合成]
* 创建表完成后追加表备注,创建过程能添加备注的不需要实现与comment(DataRuntime runtime, StringBuilder builder, Table meta)二选一实现 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 表 * @return sql * @throws Exception 异常 */ @Override public List buildAppendCommentRun(DataRuntime runtime, PartitionTable meta) throws Exception { return super.buildAppendCommentRun(runtime, meta); } /** * partition table[命令合成]
* 修改分区表 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 表 * @return sql * @throws Exception 异常 */ @Override public List buildAlterRun(DataRuntime runtime, PartitionTable meta) throws Exception { return super.buildAlterRun(runtime, meta); } /** * partition table[命令合成-]
* 删除分区表 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 表 * @return sql * @throws Exception 异常 */ @Override public List buildDropRun(DataRuntime runtime, PartitionTable meta) throws Exception { return super.buildDropRun(runtime, meta); } /** * partition table[命令合成]
* 分区表重命名 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 分区表 * @return sql * @throws Exception 异常 */ @Override public List buildRenameRun(DataRuntime runtime, PartitionTable meta) throws Exception { return super.buildRenameRun(runtime, meta); } /** * partition table[命令合成-子流程]
* 修改分区表备注 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 表 * @return sql * @throws Exception 异常 */ @Override public List buildChangeCommentRun(DataRuntime runtime, PartitionTable meta) throws Exception { return super.buildChangeCommentRun(runtime, meta); } /* ***************************************************************************************************************** * column * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * boolean add(DataRuntime runtime, Column meta) * boolean alter(DataRuntime runtime, Table table, Column meta, boolean trigger) * boolean alter(DataRuntime runtime, Column meta) * boolean drop(DataRuntime runtime, Column meta) * boolean rename(DataRuntime runtime, Column origin, String name) * [命令合成] * List buildAddRun(DataRuntime runtime, Column column, boolean slice) * List buildAddRun(DataRuntime runtime, Column column) * List buildAlterRun(DataRuntime runtime, Column column, boolean slice) * List buildAlterRun(DataRuntime runtime, Column column) * List buildDropRun(DataRuntime runtime, Column column, boolean slice) * List buildDropRun(DataRuntime runtime, Column column) * List buildRenameRun(DataRuntime runtime, Column column) * [命令合成-子流程] * List buildChangeTypeRun(DataRuntime runtime, Column column) * String alterColumnKeyword(DataRuntime runtime) * StringBuilder addColumnGuide(DataRuntime runtime, StringBuilder builder, Column column) * StringBuilder dropColumnGuide(DataRuntime runtime, StringBuilder builder, Column column) * List buildChangeDefaultRun(DataRuntime runtime, Column column) * List buildChangeNullableRun(DataRuntime runtime, Column column) * List buildChangeCommentRun(DataRuntime runtime, Column column) * List buildAppendCommentRun(DataRuntime runtime, Column column) * List buildDropAutoIncrement(DataRuntime runtime, Column column) * StringBuilder define(DataRuntime runtime, StringBuilder builder, Column meta, ACTION.DDL action) * StringBuilder type(DataRuntime runtime, StringBuilder builder, Column column) * StringBuilder type(DataRuntime runtime, StringBuilder builder, Column column, String type, int ignorePrecision, boolean ignoreScale) * int ignorePrecision(DataRuntime runtime, Column column) * int ignoreScale(DataRuntime runtime, Column column) * Boolean checkIgnorePrecision(DataRuntime runtime, String datatype) * int checkIgnoreScale(DataRuntime runtime, String datatype) * StringBuilder nullable(DataRuntime runtime, StringBuilder builder, Column meta, ACTION.DDL action) * StringBuilder charset(DataRuntime runtime, StringBuilder builder, Column column) * StringBuilder defaultValue(DataRuntime runtime, StringBuilder builder, Column column) * StringBuilder primary(DataRuntime runtime, StringBuilder builder, Column column) * StringBuilder increment(DataRuntime runtime, StringBuilder builder, Column column) * StringBuilder onupdate(DataRuntime runtime, StringBuilder builder, Column column) * StringBuilder position(DataRuntime runtime, StringBuilder builder, Column column) * StringBuilder comment(DataRuntime runtime, StringBuilder builder, Column column) * StringBuilder checkColumnExists(DataRuntime runtime, StringBuilder builder, boolean exists) ******************************************************************************************************************/ /** * column[调用入口]
* 添加列,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 列 * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean add(DataRuntime runtime, Column meta) throws Exception { return super.add(runtime, meta); } /** * column[调用入口]
* 修改列,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 列 * @param trigger 修改异常时,是否触发监听器 * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean alter(DataRuntime runtime, Table table, Column meta, boolean trigger) throws Exception { return super.alter(runtime, table, meta, trigger); } /** * column[调用入口]
* 修改列,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 列 * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean alter(DataRuntime runtime, Column meta) throws Exception { return super.alter(runtime, meta); } /** * column[调用入口]
* 删除列,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 列 * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean drop(DataRuntime runtime, Column meta) throws Exception { return super.drop(runtime, meta); } /** * column[调用入口]
* 重命名列,执行的命令通过meta.ddls()返回 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param origin 列 * @param name 新名称 * @return boolean 是否执行成功 * @throws Exception DDL异常 */ @Override public boolean rename(DataRuntime runtime, Column origin, String name) throws Exception { return super.rename(runtime, origin, name); } /** * column[命令合成]
* 添加列 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 列 * @param slice 是否只生成片段(不含alter table部分,用于DDL合并) * @return String */ @Override public List buildAddRun(DataRuntime runtime, Column meta, boolean slice) throws Exception { return super.buildAddRun(runtime, meta, slice);/* List runs = new ArrayList<>(); Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); if(!slice(slice)) { Table table = meta.getTable(true); builder.append("ALTER TABLE "); name(runtime, builder, table); }else{ run.slice(slice); } Column update = meta.getUpdate(); if(null == update) { // 添加列 addColumnGuide(runtime, builder, meta); delimiter(builder, meta.getName()).append(" "); define(runtime, builder, meta, ACTION.DDL.COLUMN_ADD); *//* // 数据类型 type(runtime, builder, meta); // 编码 charset(runtime, builder, meta); // 默认值 defaultValue(runtime, builder, meta); // 非空 nullable(runtime, builder, meta, ACTION.DDL.COLUMN_ADD); // 更新事件 onupdate(runtime, builder, meta); // 备注 comment(runtime, builder, meta); // 位置 position(runtime, builder, meta);*//* } runs.addAll(buildAppendCommentRun(runtime, meta)); return runs;*/ } /** * column[命令合成]
* 修改列 * 修改列 ALTER TABLE HR_USER CHANGE UPT_TIME UPT_TIME datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP comment '修改时间' AFTER ID; * 有可能生成多条SQL * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 列 * @param slice 是否只生成片段(不含alter table部分,用于DDL合并) * @return List */ @Override public List buildAlterRun(DataRuntime runtime, Column meta, boolean slice) throws Exception { List runs = new ArrayList<>(); Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); if(!slice(slice)) { Table table = meta.getTable(true); builder.append("ALTER TABLE "); name(runtime, builder, table); }else{ run.slice(slice); } Column update = meta.getUpdate(); if(null == update) { update = meta; } boolean rename = meta.isRename(); if(rename) { builder.append(" CHANGE "); }else{ builder.append(" MODIFY ").append(alterColumnKeyword(runtime)); } delimiter(builder, meta.getName()).append(" "); if(rename) { delimiter(builder, update.getName()).append(" "); } define(runtime, builder, update, ACTION.DDL.COLUMN_ADD); return runs; } /** * column[命令合成]
* 删除列 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 列 * @param slice 是否只生成片段(不含alter table部分,用于DDL合并) * @return String */ @Override public List buildDropRun(DataRuntime runtime, Column meta, boolean slice) throws Exception { return super.buildDropRun(runtime, meta, slice); } /** * column[命令合成]
* 修改列名 * 一般不直接调用,如果需要由buildAlterRun内部统一调用 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 列 * @return String */ @Override public List buildRenameRun(DataRuntime runtime, Column meta, boolean slice) throws Exception { return super.buildRenameRun(runtime, meta, slice); } /** * column[命令合成-子流程]
* 修改数据类型 * 一般不直接调用,如果需要由buildAlterRun内部统一调用 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 列 * @return String */ @Override public List buildChangeTypeRun(DataRuntime runtime, Column meta, boolean slice) throws Exception { return super.buildChangeTypeRun(runtime, meta, slice); } /** * column[命令合成-子流程]
* 修改表的关键字 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @return String */ @Override public String alterColumnKeyword(DataRuntime runtime) { return " COLUMN "; } /** * column[命令合成-子流程]
* 添加列引导 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder StringBuilder * @param meta 列 * @return String */ @Override public StringBuilder addColumnGuide(DataRuntime runtime, StringBuilder builder, Column meta) { return super.addColumnGuide(runtime, builder, meta); } /** * column[命令合成-子流程]
* 删除列引导 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder StringBuilder * @param meta 列 * @return String */ @Override public StringBuilder dropColumnGuide(DataRuntime runtime, StringBuilder builder, Column meta) { return super.dropColumnGuide(runtime, builder, meta); } /** * column[命令合成-子流程]
* 修改默认值 * 一般不直接调用,如果需要由buildAlterRun内部统一调用 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 列 * @return String */ @Override public List buildChangeDefaultRun(DataRuntime runtime, Column meta, boolean slice) throws Exception { return super.buildChangeDefaultRun(runtime, meta, slice); } /** * column[命令合成-子流程]
* 修改非空限制 * 一般不直接调用,如果需要由buildAlterRun内部统一调用 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 列 * @return String */ @Override public List buildChangeNullableRun(DataRuntime runtime, Column meta, boolean slice) throws Exception { return super.buildChangeNullableRun(runtime, meta, slice); } /** * column[命令合成-子流程]
* 修改备注 * 一般不直接调用,如果需要由buildAlterRun内部统一调用 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 列 * @return String */ @Override public List buildChangeCommentRun(DataRuntime runtime, Column meta, boolean slice) throws Exception { return super.buildChangeCommentRun(runtime, meta, slice); } /** * column[命令合成-子流程]
* 创建表完成后追加表备注,创建过程能添加备注的不需要实现与comment(DataRuntime runtime, StringBuilder builder, Table meta)二选一实现 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param column 列 * @return sql * @throws Exception 异常 */ /** * 创建表完成后追加表备注,创建过程能添加备注的不需要实现与comment(DataRuntime runtime, StringBuilder builder, Table meta)二选一实现 * @param meta 列 * @return sql * @throws Exception 异常 */ @Override public List buildAppendCommentRun(DataRuntime runtime, Column meta, boolean slice) throws Exception { return super.buildAppendCommentRun(runtime, meta, slice); } /** * column[命令合成-子流程]
* 取消自增 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 列 * @return sql * @throws Exception 异常 */ @Override public List buildDropAutoIncrement(DataRuntime runtime, Column meta, boolean slice) throws Exception { meta.update().autoIncrement(false); return buildAlterRun(runtime, meta, slice); } /** * column[命令合成-子流程]
* 定义列,依次拼接下面几个属性注意不同数据库可能顺序不一样 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param meta 列 * @return StringBuilder */ @Override public StringBuilder define(DataRuntime runtime, StringBuilder builder, Column meta, ACTION.DDL action) { return super.define(runtime, builder, meta, action); } /** * column[命令合成-子流程]
* 列定义:创建或删除列之前 检测表是否存在 * IF NOT EXISTS * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param exists exists * @return StringBuilder */ @Override public StringBuilder checkColumnExists(DataRuntime runtime, StringBuilder builder, boolean exists) { return super.checkColumnExists(runtime, builder, exists); } /** * column[命令合成-子流程]
* 列定义:数据类型 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param meta 列 * @return StringBuilder */ @Override public StringBuilder type(DataRuntime runtime, StringBuilder builder, Column meta) { return super.type(runtime, builder, meta); } /** * column[命令合成-子流程]
* 列定义:数据类型定义 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param meta 列 * @param type 数据类型(已经过转换) * @param ignorePrecision 是否忽略长度 * @param ignoreScale 是否忽略小数 * @return StringBuilder */ @Override public StringBuilder type(DataRuntime runtime, StringBuilder builder, Column meta, String type, int ignoreLength, int ignorePrecision, int ignoreScale) { return super.type(runtime, builder, meta, type, ignoreLength, ignorePrecision, ignoreScale); } /** * column[命令合成-子流程]
* 列定义:非空 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param meta 列 * @return StringBuilder */ @Override public StringBuilder nullable(DataRuntime runtime, StringBuilder builder, Column meta, ACTION.DDL action) { return super.nullable(runtime, builder, meta, action); } /** * column[命令合成-子流程]
* 列定义:编码 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param meta 列 * @return StringBuilder */ @Override public StringBuilder charset(DataRuntime runtime, StringBuilder builder, Column meta) { // CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci String typeName = meta.getTypeName(); if(null != typeName && typeName.toLowerCase().contains("char")) { String charset = meta.getCharset(); if (BasicUtil.isNotEmpty(charset)) { builder.append(" CHARACTER SET ").append(charset); String collate = meta.getCollate(); if (BasicUtil.isNotEmpty(collate)) { builder.append(" COLLATE ").append(collate); } } } return builder; } /** * column[命令合成-子流程]
* 列定义:默认值 * @param builder builder * @param meta 列 * @return StringBuilder */ @Override public StringBuilder defaultValue(DataRuntime runtime, StringBuilder builder, Column meta) { return super.defaultValue(runtime, builder, meta); } /** * column[命令合成-子流程]
* 列定义:定义列的主键标识(注意不要跟表定义中的主键重复) * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param meta 列 * @return StringBuilder */ @Override public StringBuilder primary(DataRuntime runtime, StringBuilder builder, Column meta) { //不在列上实现了,因为还有其他主键属性需要设置 PRIMARY KEY(ID) USING BTREE /* if(null != meta && meta.isPrimaryKey() == 1) { Table table = meta.getTable(); int size = table.getPrimaryKeySize(); //如果是修改状态 并且 列名没变 并且 主键没变 则忽略 if(meta.getAction() == ACTION.DDL.COLUMN_ALTER) { if(!meta.isRename()) { return builder; } } if(size ==1) {//单键时 在列名上设置 builder.append(" PRIMARY KEY"); } }*/ return builder; } /** * column[命令合成-子流程]
* 列定义:唯一索引 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param meta 列 * @return StringBuilder */ @Override public StringBuilder unique(DataRuntime runtime, StringBuilder builder, Column meta) { if(meta.isPrimaryKey() != 1) { if(meta.isUnique() == 1) { builder.append(" UNIQUE"); } } return builder; } /** * column[命令合成-子流程]
* 列定义:递增列,需要通过serial实现递增的在type(DataRuntime runtime, StringBuilder builder, Column meta)中实现 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param meta 列 * @return StringBuilder */ @Override public StringBuilder increment(DataRuntime runtime, StringBuilder builder, Column meta) { if(meta.isAutoIncrement() == 1) { builder.append(" AUTO_INCREMENT"); } return builder; } /** * column[命令合成-子流程]
* 列定义:更新行事件 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param meta 列 * @return StringBuilder */ @Override public StringBuilder onupdate(DataRuntime runtime, StringBuilder builder, Column meta) { String onUpdate = meta.getOnUpdate(); if(BasicUtil.isNotEmpty(onUpdate)) { builder.append(" ON UPDATE ").append(onUpdate); } return builder; } /** * column[命令合成-子流程]
* 列定义:位置 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param meta 列 * @return StringBuilder */ @Override public StringBuilder position(DataRuntime runtime, StringBuilder builder, Column meta) { if(!ConfigTable.IS_ENABLE_COLUMN_POSITION) { return builder; } Integer position = meta.getPosition(); String after = meta.getAfter(); String before = meta.getBefore(); if(BasicUtil.isEmpty(before) && BasicUtil.isEmpty(after)) { if(null != position && 0 == position) { builder.append(" FIRST"); } }else{ if(BasicUtil.isNotEmpty(after)) { builder.append(" AFTER "); delimiter(builder, after); }else if(BasicUtil.isNotEmpty(before)) { builder.append(" BEFORE "); delimiter(builder, before); } } return builder; } /** * column[命令合成-子流程]
* 列定义:备注 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param meta 列 * @return StringBuilder */ @Override public StringBuilder comment(DataRuntime runtime, StringBuilder builder, Column meta) { String comment = meta.getComment(); if(BasicUtil.isNotEmpty(comment)) { builder.append(" COMMENT '").append(comment).append("'"); } return builder; } /* ***************************************************************************************************************** * tag * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * boolean add(DataRuntime runtime, Tag meta) * boolean alter(DataRuntime runtime, Table table, Tag meta, boolean trigger) * boolean alter(DataRuntime runtime, Tag meta) * boolean drop(DataRuntime runtime, Tag meta) * boolean rename(DataRuntime runtime, Tag origin, String name) * [命令合成] * List buildAddRun(DataRuntime runtime, Tag meta) * List buildAlterRun(DataRuntime runtime, Tag meta) * List buildDropRun(DataRuntime runtime, Tag meta, boolean slice) * List buildRenameRun(DataRuntime runtime, Tag meta, boolean slice) * List buildChangeDefaultRun(DataRuntime runtime, Tag meta) * List buildChangeNullableRun(DataRuntime runtime, Tag meta) * List buildChangeCommentRun(DataRuntime runtime, Tag meta) * List buildChangeTypeRun(DataRuntime runtime, Tag meta) * StringBuilder checkTagExists(DataRuntime runtime, StringBuilder builder, boolean exists) ******************************************************************************************************************/ /** * tag[调用入口]
* 添加标签 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 标签 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean add(DataRuntime runtime, Tag meta) throws Exception { return super.add(runtime, meta); } /** * tag[调用入口]
* 修改标签 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 标签 * @param trigger 修改异常时,是否触发监听器 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean alter(DataRuntime runtime, Table table, Tag meta, boolean trigger) throws Exception { return super.alter(runtime, table, meta, trigger); } /** * tag[调用入口]
* 修改标签 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 标签 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean alter(DataRuntime runtime, Tag meta) throws Exception { return super.alter(runtime, meta); } /** * tag[调用入口]
* 删除标签 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 标签 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean drop(DataRuntime runtime, Tag meta) throws Exception { return super.drop(runtime, meta); } /** * tag[调用入口]
* 重命名标签 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param origin 原标签 * @param name 新名称 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean rename(DataRuntime runtime, Tag origin, String name) throws Exception { return super.rename(runtime, origin, name); } /** * tag[命令合成]
* 添加标签 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 标签 * @return String */ @Override public List buildAddRun(DataRuntime runtime, Tag meta, boolean slice) throws Exception { return new ArrayList<>(); } /** * tag[命令合成]
* 修改标签 * 有可能生成多条SQL * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 标签 * @return List */ @Override public List buildAlterRun(DataRuntime runtime, Tag meta, boolean slice) throws Exception { return new ArrayList<>(); } /** * tag[命令合成]
* 删除标签 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 标签 * @return String */ @Override public List buildDropRun(DataRuntime runtime, Tag meta, boolean slice) throws Exception { return new ArrayList<>(); } /** * tag[命令合成]
* 修改标签名 * 一般不直接调用,如果需要由buildAlterRun内部统一调用 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 标签 * @return String */ @Override public List buildRenameRun(DataRuntime runtime, Tag meta, boolean slice) throws Exception { return new ArrayList<>(); } /** * tag[命令合成]
* 修改默认值 * 一般不直接调用,如果需要由buildAlterRun内部统一调用 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 标签 * @return String */ @Override public List buildChangeDefaultRun(DataRuntime runtime, Tag meta, boolean slice) throws Exception { return new ArrayList<>(); } /** * tag[命令合成]
* 修改非空限制 * 一般不直接调用,如果需要由buildAlterRun内部统一调用 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 标签 * @return String */ @Override public List buildChangeNullableRun(DataRuntime runtime, Tag meta, boolean slice) throws Exception { return new ArrayList<>(); } /** * tag[命令合成]
* 修改备注 * 一般不直接调用,如果需要由buildAlterRun内部统一调用 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 标签 * @return String */ @Override public List buildChangeCommentRun(DataRuntime runtime, Tag meta, boolean slice) throws Exception { return new ArrayList<>(); } /** * tag[命令合成]
* 修改数据类型 * 一般不直接调用,如果需要由buildAlterRun内部统一调用 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 标签 * @return String */ @Override public List buildChangeTypeRun(DataRuntime runtime, Tag meta, boolean slice) throws Exception { return new ArrayList<>(); } /** * tag[命令合成]
* 创建或删除标签之前 检测表是否存在 * IF NOT EXISTS * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param exists exists * @return StringBuilder */ @Override public StringBuilder checkTagExists(DataRuntime runtime, StringBuilder builder, boolean exists) { return builder; } /* ***************************************************************************************************************** * primary * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * boolean add(DataRuntime runtime, PrimaryKey meta) * boolean alter(DataRuntime runtime, PrimaryKey meta) * boolean alter(DataRuntime runtime, Table table, PrimaryKey meta) * boolean drop(DataRuntime runtime, PrimaryKey meta) * boolean rename(DataRuntime runtime, PrimaryKey origin, String name) * [命令合成] * List buildAddRun(DataRuntime runtime, PrimaryKey primary) * List buildAlterRun(DataRuntime runtime, PrimaryKey primary) * List buildDropRun(DataRuntime runtime, PrimaryKey primary) * List buildRenameRun(DataRuntime runtime, PrimaryKey primary) ******************************************************************************************************************/ /** * primary[调用入口]
* 添加主键 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 主键 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean add(DataRuntime runtime, PrimaryKey meta) throws Exception { return super.add(runtime, meta); } /** * primary[调用入口]
* 修改主键 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 主键 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean alter(DataRuntime runtime, PrimaryKey meta) throws Exception { return super.alter(runtime, meta); } /** * primary[调用入口]
* 修改主键 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 主键 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean alter(DataRuntime runtime, Table table, PrimaryKey meta) throws Exception { return super.alter(runtime, table, meta); } /** * primary[调用入口]
* 删除主键 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 主键 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean drop(DataRuntime runtime, PrimaryKey meta) throws Exception { return super.drop(runtime, meta); } /** * primary[调用入口]
* 添加主键 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param origin 主键 * @param name 新名称 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean rename(DataRuntime runtime, PrimaryKey origin, String name) throws Exception { return super.rename(runtime, origin, name); } /** * primary[命令合成]
* 添加主键 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 主键 * @param slice 是否只生成片段(不含alter table部分,用于DDL合并) * @return String */ @Override public List buildAddRun(DataRuntime runtime, PrimaryKey meta, boolean slice) throws Exception { List runs = new ArrayList<>(); Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); LinkedHashMap columns = meta.getColumns(); if(null != columns && !columns.isEmpty()) { if(!slice(slice)) { builder.append("ALTER TABLE "); name(runtime, builder, meta.getTable(true)); }else{ run.slice(slice); } builder.append(" ADD PRIMARY KEY ("); Column.sort(meta.getPositions(), columns); delimiter(builder, Column.names(columns)); builder.append(")"); String type = meta.getType(); if(BasicUtil.isNotEmpty(type)) { builder.append(" USING ").append(type); } } return runs; } /** * primary[命令合成]
* 修改主键 * 有可能生成多条SQL * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param origin 原主键 * @param meta 新主键 * @return List */ @Override public List buildAlterRun(DataRuntime runtime, PrimaryKey origin, PrimaryKey meta, boolean slice) throws Exception { return super.buildAlterRun(runtime, origin, meta, slice); } /** * primary[命令合成]
* 删除主键 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 主键 * @param slice 是否只生成片段(不含alter table部分,用于DDL合并) * @return String */ @Override public List buildDropRun(DataRuntime runtime, PrimaryKey meta, boolean slice) throws Exception { List runs = new ArrayList<>(); Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); if(!slice(slice)) { builder.append("ALTER TABLE "); name(runtime, builder, meta.getTable(true)); }else{ run.slice(slice); } builder.append(" DROP PRIMARY KEY"); return runs; } /** * primary[命令合成]
* 修改主键名 * 一般不直接调用,如果需要由buildAlterRun内部统一调用 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 主键 * @return String */ @Override public List buildRenameRun(DataRuntime runtime, PrimaryKey meta) throws Exception { return super.buildRenameRun(runtime, meta); } /* ***************************************************************************************************************** * foreign * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * boolean add(DataRuntime runtime, ForeignKey meta) * boolean alter(DataRuntime runtime, ForeignKey meta) * boolean alter(DataRuntime runtime, Table table, ForeignKey meta) * boolean drop(DataRuntime runtime, ForeignKey meta) * boolean rename(DataRuntime runtime, ForeignKey origin, String name) * [命令合成] * List buildAddRun(DataRuntime runtime, ForeignKey meta) * List buildAlterRun(DataRuntime runtime, ForeignKey meta) * List buildDropRun(DataRuntime runtime, ForeignKey meta) * List buildRenameRun(DataRuntime runtime, ForeignKey meta) ******************************************************************************************************************/ /** * foreign[调用入口]
* 添加外键 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 外键 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean add(DataRuntime runtime, ForeignKey meta) throws Exception { return super.add(runtime, meta); } /** * foreign[调用入口]
* 修改外键 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 外键 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean alter(DataRuntime runtime, ForeignKey meta) throws Exception { return super.alter(runtime, meta); } /** * foreign[调用入口]
* 修改外键 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 外键 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean alter(DataRuntime runtime, Table table, ForeignKey meta) throws Exception { return super.alter(runtime, table, meta); } /** * foreign[调用入口]
* 删除外键 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 外键 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean drop(DataRuntime runtime, ForeignKey meta) throws Exception { return super.drop(runtime, meta); } /** * foreign[调用入口]
* 重命名外键 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param origin 外键 * @param name 新名称 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean rename(DataRuntime runtime, ForeignKey origin, String name) throws Exception { return super.rename(runtime, origin, name); } /** * foreign[命令合成]
* 添加外键 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 外键 * @return String */ @Override public List buildAddRun(DataRuntime runtime, ForeignKey meta) throws Exception { return super.buildAddRun(runtime, meta); } /** * foreign[命令合成]
* 修改外键 * @param meta 外键 * @return List */ /** * 添加外键 * @param meta 外键 * @return List */ @Override public List buildAlterRun(DataRuntime runtime, ForeignKey meta) throws Exception { return super.buildAlterRun(runtime, meta); } /** * foreign[命令合成]
* 删除外键 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 外键 * @return String */ @Override public List buildDropRun(DataRuntime runtime, ForeignKey meta) throws Exception { return super.buildDropRun(runtime, meta); } /** * foreign[命令合成]
* 修改外键名 * 一般不直接调用,如果需要由buildAlterRun内部统一调用 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 外键 * @return String */ @Override public List buildRenameRun(DataRuntime runtime, ForeignKey meta) throws Exception { return super.buildRenameRun(runtime, meta); } /* ***************************************************************************************************************** * index * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * boolean add(DataRuntime runtime, Index meta) * boolean alter(DataRuntime runtime, Index meta) * boolean alter(DataRuntime runtime, Table table, Index meta) * boolean drop(DataRuntime runtime, Index meta) * boolean rename(DataRuntime runtime, Index origin, String name) * [命令合成] * List buildAppendIndexRun(DataRuntime runtime, Table meta) * List buildAlterRun(DataRuntime runtime, Index meta) * List buildDropRun(DataRuntime runtime, Index meta) * List buildRenameRun(DataRuntime runtime, Index meta) * [命令合成-子流程] * StringBuilder type(DataRuntime runtime, StringBuilder builder, Index meta) * StringBuilder comment(DataRuntime runtime, StringBuilder builder, Index meta) ******************************************************************************************************************/ /** * index[调用入口]
* 添加索引 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 索引 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean add(DataRuntime runtime, Index meta) throws Exception { return super.add(runtime, meta); } /** * index[调用入口]
* 修改索引 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 索引 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean alter(DataRuntime runtime, Index meta) throws Exception { return super.alter(runtime, meta); } /** * index[调用入口]
* 修改索引 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 索引 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean alter(DataRuntime runtime, Table table, Index meta) throws Exception { Map origins = indexes(runtime, null, table, meta.getName()); if(!origins.isEmpty()) { drop(runtime, meta); } return add(runtime, meta); } /** * index[调用入口]
* 删除索引 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 索引 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean drop(DataRuntime runtime, Index meta) throws Exception { return super.drop(runtime, meta); } /** * index[调用入口]
* 重命名索引 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param origin 索引 * @param name 新名称 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean rename(DataRuntime runtime, Index origin, String name) throws Exception { return super.rename(runtime, origin, name); } /** * index[命令合成]
* 添加索引 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 索引 * @return String */ @Override public List buildAppendIndexRun(DataRuntime runtime, Table meta) throws Exception { return super.buildAppendIndexRun(runtime, meta); } /** * index[命令合成]
* 修改索引 * 有可能生成多条SQL * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 索引 * @return List */ @Override public List buildAlterRun(DataRuntime runtime, Index meta) throws Exception { return super.buildAlterRun(runtime, meta); } /** * index[命令合成]
* 删除索引 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 索引 * @return String */ @Override public List buildDropRun(DataRuntime runtime, Index meta) throws Exception { List runs = new ArrayList<>(); Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); builder.append("ALTER TABLE "); name(runtime, builder, meta.getTable(true)); if(meta.isPrimary()) { builder.append(" DROP PRIMARY KEY"); }else { builder.append(" DROP INDEX ").append(meta.getName()); } return runs; } /** * index[命令合成]
* 修改索引名 * 一般不直接调用,如果需要由buildAlterRun内部统一调用 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 索引 * @return String */ @Override public List buildRenameRun(DataRuntime runtime, Index meta) throws Exception { return super.buildRenameRun(runtime, meta); } /** * index[命令合成-子流程]
* 索引类型 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 索引 * @param builder builder * @return StringBuilder */ @Override public StringBuilder type(DataRuntime runtime, StringBuilder builder, Index meta) { String type = meta.getType(); if(BasicUtil.isNotEmpty(type)) { builder.append("USING ").append(type).append(" "); } return builder; } /** * index[命令合成-子流程]
* 索引备注 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 索引 * @param builder builder * @return StringBuilder */ @Override public StringBuilder comment(DataRuntime runtime, StringBuilder builder, Index meta) { String comment = meta.getComment(); if(BasicUtil.isNotEmpty(comment)) { builder.append(" COMMENT '").append(comment).append("'"); }; return builder; } /* ***************************************************************************************************************** * constraint * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * boolean add(DataRuntime runtime, Constraint meta) * boolean alter(DataRuntime runtime, Constraint meta) * boolean alter(DataRuntime runtime, Table table, Constraint meta) * boolean drop(DataRuntime runtime, Constraint meta) * boolean rename(DataRuntime runtime, Constraint origin, String name) * [命令合成] * List buildAddRun(DataRuntime runtime, Constraint meta) * List buildAlterRun(DataRuntime runtime, Constraint meta) * List buildDropRun(DataRuntime runtime, Constraint meta) * List buildRenameRun(DataRuntime runtime, Constraint meta) ******************************************************************************************************************/ /** * constraint[调用入口]
* 添加约束 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 约束 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean add(DataRuntime runtime, Constraint meta) throws Exception { return super.add(runtime, meta); } /** * constraint[调用入口]
* 修改约束 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 约束 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean alter(DataRuntime runtime, Constraint meta) throws Exception { return super.alter(runtime, meta); } /** * constraint[调用入口]
* 修改约束 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 约束 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean alter(DataRuntime runtime, Table table, Constraint meta) throws Exception { return super.alter(runtime, table, meta); } /** * constraint[调用入口]
* 删除约束 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 约束 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean drop(DataRuntime runtime, Constraint meta) throws Exception { return super.drop(runtime, meta); } /** * constraint[调用入口]
* 重命名约束 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param origin 约束 * @param name 新名称 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean rename(DataRuntime runtime, Constraint origin, String name) throws Exception { return super.rename(runtime, origin, name); } /** * constraint[命令合成]
* 添加约束 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 约束 * @return String */ @Override public List buildAddRun(DataRuntime runtime, Constraint meta) throws Exception { return super.buildAddRun(runtime, meta); } /** * constraint[命令合成]
* 修改约束 * 有可能生成多条SQL * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 约束 * @return List */ @Override public List buildAlterRun(DataRuntime runtime, Constraint meta) throws Exception { return super.buildAlterRun(runtime, meta); } /** * constraint[命令合成]
* 删除约束 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 约束 * @return String */ @Override public List buildDropRun(DataRuntime runtime, Constraint meta) throws Exception { return super.buildDropRun(runtime, meta); } /** * constraint[命令合成]
* 修改约束名 * 一般不直接调用,如果需要由buildAlterRun内部统一调用 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 约束 * @return String */ @Override public List buildRenameRun(DataRuntime runtime, Constraint meta) throws Exception { return super.buildRenameRun(runtime, meta); } /* ***************************************************************************************************************** * trigger * ----------------------------------------------------------------------------------------------------------------- * List buildCreateRun(DataRuntime runtime, Trigger trigger) throws Exception * List buildAlterRun(DataRuntime runtime, Trigger trigger) throws Exception; * List buildDropRun(DataRuntime runtime, Trigger trigger) throws Exception; * List buildRenameRun(DataRuntime runtime, Trigger trigger) throws Exception; ******************************************************************************************************************/ /** * trigger[调用入口]
* 添加触发器 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 触发器 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean add(DataRuntime runtime, Trigger meta) throws Exception { return super.add(runtime, meta); } /** * trigger[调用入口]
* 修改触发器 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 触发器 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean alter(DataRuntime runtime, Trigger meta) throws Exception { return super.alter(runtime, meta); } /** * trigger[调用入口]
* 删除触发器 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 触发器 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean drop(DataRuntime runtime, Trigger meta) throws Exception { return super.drop(runtime, meta); } /** * trigger[调用入口]
* 重命名触发器 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param origin 触发器 * @param name 新名称 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean rename(DataRuntime runtime, Trigger origin, String name) throws Exception { return super.rename(runtime, origin, name); } /** * trigger[命令合成]
* 添加触发器 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 触发器 * @return List */ @Override public List buildCreateRun(DataRuntime runtime, Trigger meta) throws Exception { return super.buildCreateRun(runtime, meta); } /** * trigger[命令合成]
* 修改触发器 * 有可能生成多条SQL * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 触发器 * @return List */ @Override public List buildAlterRun(DataRuntime runtime, Trigger meta) throws Exception { return super.buildAlterRun(runtime, meta); } /** * trigger[命令合成]
* 删除触发器 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 触发器 * @return List */ @Override public List buildDropRun(DataRuntime runtime, Trigger meta) throws Exception { return super.buildDropRun(runtime, meta); } /** * trigger[命令合成]
* 修改触发器名 * 一般不直接调用,如果需要由buildAlterRun内部统一调用 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 触发器 * @return List */ @Override public List buildRenameRun(DataRuntime runtime, Trigger meta) throws Exception { return super.buildRenameRun(runtime, meta); } /** * trigger[命令合成-子流程]
* 触发级别(行或整个命令) * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 触发器 * @param builder builder * @return StringBuilder */ @Override public StringBuilder each(DataRuntime runtime, StringBuilder builder, Trigger meta) { return super.each(runtime, builder, meta); } /* ***************************************************************************************************************** * procedure * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * boolean create(DataRuntime runtime, Procedure meta) * boolean alter(DataRuntime runtime, Procedure meta) * boolean drop(DataRuntime runtime, Procedure meta) * boolean rename(DataRuntime runtime, Procedure origin, String name) * [命令合成] * List buildCreateRun(DataRuntime runtime, Procedure meta) * List buildAlterRun(DataRuntime runtime, Procedure meta) * List buildDropRun(DataRuntime runtime, Procedure meta) * List buildRenameRun(DataRuntime runtime, Procedure meta) * [命令合成-子流程] * StringBuilder parameter(DataRuntime runtime, StringBuilder builder, Parameter parameter) ******************************************************************************************************************/ /** * procedure[调用入口]
* 添加存储过程 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 存储过程 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean create(DataRuntime runtime, Procedure meta) throws Exception { return super.create(runtime, meta); } /** * procedure[调用入口]
* 修改存储过程 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 存储过程 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean alter(DataRuntime runtime, Procedure meta) throws Exception { return super.alter(runtime, meta); } /** * procedure[调用入口]
* 删除存储过程 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 存储过程 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean drop(DataRuntime runtime, Procedure meta) throws Exception { return super.drop(runtime, meta); } /** * procedure[调用入口]
* 重命名存储过程 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param origin 存储过程 * @param name 新名称 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean rename(DataRuntime runtime, Procedure origin, String name) throws Exception { return super.rename(runtime, origin, name); } /** * procedure[命令合成]
* 添加存储过程 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 存储过程 * @return String */ @Override public List buildCreateRun(DataRuntime runtime, Procedure meta) throws Exception { return super.buildCreateRun(runtime, meta); } /** * procedure[命令合成]
* 修改存储过程 * 有可能生成多条SQL * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 存储过程 * @return List */ @Override public List buildAlterRun(DataRuntime runtime, Procedure meta) throws Exception { return super.buildAlterRun(runtime, meta); } /** * procedure[命令合成]
* 删除存储过程 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 存储过程 * @return String */ @Override public List buildDropRun(DataRuntime runtime, Procedure meta) throws Exception { return super.buildDropRun(runtime, meta); } /** * procedure[命令合成]
* 修改存储过程名
* 一般不直接调用,如果需要由buildAlterRun内部统一调用 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 存储过程 * @return String */ @Override public List buildRenameRun(DataRuntime runtime, Procedure meta) throws Exception { log.warn("MySQL不支持 rename procedure("+meta.getName()+")"); return new ArrayList<>(); } /** * procedure[命令合成-子流程]
* 生在输入输出参数 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param builder builder * @param parameter parameter */ @Override public StringBuilder parameter(DataRuntime runtime, StringBuilder builder, Parameter parameter) { return super.parameter(runtime, builder, parameter); } /* ***************************************************************************************************************** * function * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * boolean create(DataRuntime runtime, Function meta) * boolean alter(DataRuntime runtime, Function meta) * boolean drop(DataRuntime runtime, Function meta) * boolean rename(DataRuntime runtime, Function origin, String name) * [命令合成] * List buildCreateRun(DataRuntime runtime, Function function) * List buildAlterRun(DataRuntime runtime, Function function) * List buildDropRun(DataRuntime runtime, Function function) * List buildRenameRun(DataRuntime runtime, Function function) ******************************************************************************************************************/ /** * function[调用入口]
* 添加函数 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 函数 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean create(DataRuntime runtime, Function meta) throws Exception { return super.create(runtime, meta); } /** * function[调用入口]
* 修改函数 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 函数 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean alter(DataRuntime runtime, Function meta) throws Exception { return super.alter(runtime, meta); } /** * function[调用入口]
* 删除函数 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 函数 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean drop(DataRuntime runtime, Function meta) throws Exception { return super.drop(runtime, meta); } /** * function[调用入口]
* 重命名函数 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param origin 函数 * @param name 新名称 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean rename(DataRuntime runtime, Function origin, String name) throws Exception { return super.rename(runtime, origin, name); } /** * function[命令合成]
* 添加函数 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 函数 * @return String */ @Override public List buildCreateRun(DataRuntime runtime, Function meta) throws Exception { return super.buildCreateRun(runtime, meta); } /** * function[命令合成]
* 修改函数 * 有可能生成多条SQL * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 函数 * @return List */ @Override public List buildAlterRun(DataRuntime runtime, Function meta) throws Exception { return super.buildAlterRun(runtime, meta); } /** * function[命令合成]
* 删除函数 * @param meta 函数 * @return String */ @Override public List buildDropRun(DataRuntime runtime, Function meta) throws Exception { return super.buildDropRun(runtime, meta); } /** * function[命令合成]
* 修改函数名 * 一般不直接调用,如果需要由buildAlterRun内部统一调用 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 函数 * @return String */ @Override public List buildRenameRun(DataRuntime runtime, Function meta) throws Exception { log.warn("MySQL不支持 rename Function("+meta.getName()+")"); return new ArrayList<>(); } /* ***************************************************************************************************************** * sequence * ----------------------------------------------------------------------------------------------------------------- * [调用入口] * boolean create(DataRuntime runtime, Sequence meta) * boolean alter(DataRuntime runtime, Sequence meta) * boolean drop(DataRuntime runtime, Sequence meta) * boolean rename(DataRuntime runtime, Sequence origin, String name) * [命令合成] * List buildCreateRun(DataRuntime runtime, Sequence sequence) * List buildAlterRun(DataRuntime runtime, Sequence sequence) * List buildDropRun(DataRuntime runtime, Sequence sequence) * List buildRenameRun(DataRuntime runtime, Sequence sequence) ******************************************************************************************************************/ /** * sequence[调用入口]
* 添加序列 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 序列 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean create(DataRuntime runtime, Sequence meta) throws Exception { return super.create(runtime, meta); } /** * sequence[调用入口]
* 修改序列 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 序列 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean alter(DataRuntime runtime, Sequence meta) throws Exception { return super.alter(runtime, meta); } /** * sequence[调用入口]
* 删除序列 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 序列 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean drop(DataRuntime runtime, Sequence meta) throws Exception { return super.drop(runtime, meta); } /** * sequence[调用入口]
* 重命名序列 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param origin 序列 * @param name 新名称 * @return 是否执行成功 * @throws Exception 异常 */ @Override public boolean rename(DataRuntime runtime, Sequence origin, String name) throws Exception { return super.rename(runtime, origin, name); } /** * sequence[命令合成]
* 添加序列 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 序列 * @return String */ @Override public List buildCreateRun(DataRuntime runtime, Sequence meta) throws Exception { return super.buildCreateRun(runtime, meta); } /** * sequence[命令合成]
* 修改序列 * 有可能生成多条SQL * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 序列 * @return List */ @Override public List buildAlterRun(DataRuntime runtime, Sequence meta) throws Exception { return super.buildAlterRun(runtime, meta); } /** * sequence[命令合成]
* 删除序列 * @param meta 序列 * @return String */ @Override public List buildDropRun(DataRuntime runtime, Sequence meta) throws Exception { return super.buildDropRun(runtime, meta); } /** * sequence[命令合成]
* 修改序列名 * 一般不直接调用,如果需要由buildAlterRun内部统一调用 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 序列 * @return String */ @Override public List buildRenameRun(DataRuntime runtime, Sequence meta) throws Exception { log.warn("MySQL不支持 rename Sequence("+meta.getName()+")"); return new ArrayList<>(); } /* ***************************************************************************************************************** * * Authorize * * ================================================================================================================= * roe : 角色 * user : 用户 * grant : 授权 * privilege : 权限 ******************************************************************************************************************/ /** * 执行命令 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param random 用来标记同一组命令 * @param meta Metadata(表,列等) * @param action 执行命令 * @param run 最终待执行的命令和参数(如JDBC环境中的SQL) * @return boolean */ @Override public boolean execute(DataRuntime runtime, String random, Metadata meta, ACTION.Authorize action, Run run) { return super.execute(runtime, random, meta, action, run); } /* ***************************************************************************************************************** * user * ----------------------------------------------------------------------------------------------------------------- * boolean create(DataRuntime runtime, User user) throws Exception * boolean rename(DataRuntime runtime, User origin, User update) throws Exception; * boolean drop(DataRuntime runtime, User user) throws Exception * List users(Catalog catalog, Schema schema, String pattern) throws Exception * List buildQueryUsersRun(DataRuntime runtime, Catalog catalog, Schema schema, String pattern) throws Exception * List users(DataRuntime runtime, int index, boolean create, Catalog catalog, Schema schema, List users, DataSet set) throws Exception * T init(DataRuntime runtime, int index, T meta, Catalog catalog, Schema schema, DataRow row) * T detail(DataRuntime runtime, int index, T meta, Catalog catalog, Schema schema, DataRow row) ******************************************************************************************************************/ /** * user[调用入口]
* 创建用户 * @param user 用户 * @return boolean */ @Override public boolean create(DataRuntime runtime, User user) throws Exception { return super.create(runtime, user); } /** * user[调用入口]
* 用户重命名 * @param origin 原名 * @param update 新名 * @return boolean */ @Override public boolean rename(DataRuntime runtime, User origin, User update) throws Exception { return super.rename(runtime, origin, update); } /** * user[调用入口]
* 删除用户 * @param user 用户 * @return boolean */ @Override public boolean drop(DataRuntime runtime, User user) throws Exception { return super.drop(runtime, user); } /** * user[调用入口]
* 查询用户 * @param query 查询条件 根据metadata属性 * @return List */ @Override public List users(DataRuntime runtime, String random, boolean greedy, User query) throws Exception { return super.users(runtime, random, greedy, query); } /** * user[命令合成]
* 创建用户 * @param user 用户 * @return List */ @Override public List buildCreateRun(DataRuntime runtime, User user) throws Exception { List runs = new ArrayList<>(); Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); builder.append("CREATE USER '").append(user.getName()).append("'"); String host = user.getHost(); if(BasicUtil.isNotEmpty(host)){ builder.append("@'").append(host).append("'"); } String password = user.getPassword(); if(BasicUtil.isNotEmpty(password)){ builder.append(" IDENTIFIED BY '").append(password).append("'"); } return runs; } /** * user[命令合成]
* 用户重命名 * @param origin 原名 * @param update 新名 * @return List */ @Override public List buildRenameRun(DataRuntime runtime, User origin, User update) throws Exception { return super.buildRenameRun(runtime, origin, update); } /** * user[命令合成]
* 删除用户 * @param user 用户 * @return List */ @Override public List buildDropRun(DataRuntime runtime, User user) throws Exception { List runs = new ArrayList<>(); Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); builder.append("DROP USER '").append(user.getName()).append("'"); String host = user.getHost(); if(BasicUtil.isNotEmpty(host)){ builder.append("@'").append(host).append("'"); } return runs; } /** * user[命令合成]
* 查询用户 * @param query 查询条件 根据metadata属性 * @return List */ @Override public List buildQueryUsersRun(DataRuntime runtime, boolean greedy, User query) throws Exception { List runs = new ArrayList<>(); SimpleRun run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); ConfigStore configs = run.getConfigs(); builder.append("SELECT * FROM mysql.user"); configs.and(Compare.LIKE_SIMPLE, "user", query.getName()); configs.and("Host", query.getHost()); return runs; } /** * User[结果集封装]
* User 属性与结果集对应关系 * @return MetadataFieldRefer */ @Override public MetadataFieldRefer initUserFieldRefer() { MetadataFieldRefer refer = new MetadataFieldRefer(User.class); refer.map(User.FIELD_HOST, "host"); refer.map(User.FIELD_NAME, "user"); return refer; } /** * user[结果集封装]
* 根据查询结果集构造 user * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条查询SQL 对照 buildQueryUserssRun 返回顺序 * @param create 上一步没有查到的,这一步是否需要新创建 * @param query 查询条件 根据metadata属性 * @param previous 上一步查询结果 * @param set 查询结果集 * @return List * @throws Exception 异常 */ @Override public List users(DataRuntime runtime, int index, boolean create, List previous, User query, DataSet set) throws Exception { return super.users(runtime, index, create, previous, query, set); } /** * user[结果集封装]
* 根据查询结果封装 user 对象,只封装catalog,schema,name等基础属性 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 上一步封装结果 * @param query 查询条件 根据metadata属性 * @param row 查询结果集 * @return User */ @Override public T init(DataRuntime runtime, int index, T meta, User query, DataRow row) { MetadataFieldRefer refer = refer(runtime, User.class); if(null == meta) { meta = (T) new User(); } meta.setHost(row.getString(refer.maps(User.FIELD_HOST))); meta.setName(row.getString(refer.maps(User.FIELD_NAME))); return meta; } /** * user[结果集封装]
* 根据查询结果封装 user 对象,更多属性 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 上一步封装结果 * @param row 查询结果集 * @return User */ @Override public T detail(DataRuntime runtime, int index, T meta, User query, DataRow row) { return super.detail(runtime, index, meta, query, row); } /* ***************************************************************************************************************** * privilege * ----------------------------------------------------------------------------------------------------------------- * List privileges(DataRuntime runtime, User user) * List buildQueryPrivilegesRun(DataRuntime runtime, User user) throws Exception * List privileges(DataRuntime runtime, int index, boolean create, User user, List privileges, DataSet set) throws Exception * T init(DataRuntime runtime, int index, T meta, Catalog catalog, Schema schema, User user, DataRow row) * T detail(DataRuntime runtime, int index, T meta, Catalog catalog, Schema schema, DataRow row) * Privilege.MetadataAdapter privilegeMetadataAdapter(DataRuntime runtime) ******************************************************************************************************************/ /** * privilege[调用入口]
* 查询用户权限 * @param query 查询条件 根据metadata属性 * @return List */ @Override public List privileges(DataRuntime runtime, String random, boolean greedy, Privilege query) throws Exception { return super.privileges(runtime, random, greedy, query); } /** * privilege[命令合成]
* 查询用户权限 * @param query 查询条件 根据metadata属性 * @return List */ @Override public List buildQueryPrivilegesRun(DataRuntime runtime, boolean greedy, Privilege query) throws Exception { return super.buildQueryPrivilegesRun(runtime, greedy, query); } /** * privilege[结果集封装]
* 根据查询结果集构造 Trigger * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param index 第几条查询SQL 对照 buildQueryConstraintsRun 返回顺序 * @param create 上一步没有查到的,这一步是否需要新创建 * @param query 查询条件 根据metadata属性 * @param previous 上一步查询结果 * @param set 查询结果集 * @return List * @throws Exception 异常 */ @Override public List privileges(DataRuntime runtime, int index, boolean create, List previous, Privilege query, DataSet set) throws Exception { return super.privileges(runtime, index, create, previous, query, set); } /** * privilege[结果集封装]
* 根据查询结果封装Privilege对象,只封装catalog,schema,name等基础属性 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 上一步封装结果 * @param query 查询条件 根据metadata属性 * @param row 查询结果集 * @return Privilege */ @Override public T init(DataRuntime runtime, int index, T meta, Privilege query, DataRow row) { return super.init(runtime, index, meta, query, row); } /** * privilege[结果集封装]
* 根据查询结果封装Privilege对象,更多属性 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta 上一步封装结果 * @param row 查询结果集 * @return Privilege */ @Override public T detail(DataRuntime runtime, int index, T meta, Privilege query, DataRow row) { return super.detail(runtime, index, meta, query, row); } /* ***************************************************************************************************************** * grant * ----------------------------------------------------------------------------------------------------------------- * boolean grant(DataRuntime runtime, User user, Privilege ... privileges) throws Exception * List buildGrantRun(DataRuntime runtime, User user, Privilege ... privileges) throws Exception * boolean revoke(DataRuntime runtime, User user, Privilege ... privileges) throws Exception * ******************************************************************************************************************/ /** * privilege[调用入口]
* 授权 * @param user 用户 * @param privileges 权限 * @return boolean */ @Override public boolean grant(DataRuntime runtime, User user, Privilege ... privileges) throws Exception { return super.grant(runtime, user, privileges); } /** * grant[命令合成]
* 授权 * @param user 用户 * @param privileges 权限 * @return List */ @Override public List buildGrantRun(DataRuntime runtime, User user, Privilege ... privileges) throws Exception { List runs = new ArrayList<>(); for(Privilege privilege:privileges) { Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); List actions = privilege.getActions(); if(actions.isEmpty()){ actions.add(privilege.getName()); } builder.append("GRANT ").append(BeanUtil.concat(actions)); builder.append(" ON "); String database = privilege.getDatabaseName(); if(BasicUtil.isEmpty(database)){ database = privilege.getSchemaName(); } if(BasicUtil.isEmpty(database)){ database = "*"; } String objectName = privilege.getObjectName(); if(BasicUtil.isEmpty(objectName)){ objectName = "*"; } builder.append(database).append(".").append(objectName); builder.append(" TO '").append(user.getName()).append("'"); String host = user.getHost(); if (BasicUtil.isNotEmpty(host)) { builder.append("@'").append(host).append("'"); } } return runs; } /* GRANT SELECT,INSERT,UPDATE,DELETE,CREATE,DROP ON expenses. TO 'custom'@'host47.example.com';*/ /** * revoke[调用入口]
* 撤销授权 * @param user 用户 * @param privileges 权限 * @return boolean */ @Override public boolean revoke(DataRuntime runtime, User user, Privilege ... privileges) throws Exception { return super.revoke(runtime, user, privileges); } /** * revoke[命令合成]
* 撤销授权 * @param user 用户 * @param privileges 权限 * @return List */ @Override public List buildRevokeRun(DataRuntime runtime, User user, Privilege ... privileges) throws Exception { List runs = new ArrayList<>(); for(Privilege privilege:privileges) { Run run = new SimpleRun(runtime); runs.add(run); StringBuilder builder = run.getBuilder(); List actions = privilege.getActions(); if(actions.isEmpty()){ actions.add(privilege.getName()); } builder.append("REVOKE ").append(BeanUtil.concat(actions)); builder.append(" ON "); String database = privilege.getDatabaseName(); if(BasicUtil.isEmpty(database)){ database = privilege.getSchemaName(); } if(BasicUtil.isEmpty(database)){ database = "*"; } String objectName = privilege.getObjectName(); if(BasicUtil.isEmpty(objectName)){ objectName = "*"; } builder.append(database).append(".").append(objectName); builder.append(" FROM '").append(user.getName()).append("'"); String host = user.getHost(); if (BasicUtil.isNotEmpty(host)) { builder.append("@'").append(host).append("'"); } } return runs; } /* ***************************************************************************************************************** * * JDBC * * *****************************************************************************************************************/ /** * 识别根据jdbc返回的catalog与schema,部分数据库(如mysql)系统表与jdbc标准可能不一致根据实际情况处理
* 注意一定不要处理从SQL中返回的,应该在SQL中处理好 * @param meta Metadata * @param catalog 对于MySQL, 则对应相应的数据库, 对于Oracle来说, 则是对应相应的数据库实例, 可以不填, 也可以直接使用Connection的实例对象中的getCatalog()方法返回的值填充; * @param schema 可以理解为数据库的登录名, 而对于Oracle也可以理解成对该数据库操作的所有者的登录名。对于Oracle要特别注意, 其登陆名必须是大写, 不然的话是无法获取到相应的数据, 而MySQL则不做强制要求。 * @param overrideMeta 如果meta中有值,是否覆盖 * @param overrideRuntime 如果runtime中有值,是否覆盖,注意结果集中可能跨多个schema,所以一般不要覆盖runtime,从con获取的可以覆盖ResultSet中获取的不要覆盖 * @param Metadata */ @Override public void correctSchemaFromJDBC(DataRuntime runtime, T meta, String catalog, String schema, boolean overrideRuntime, boolean overrideMeta) { if(overrideMeta || empty(meta.getSchema())) { meta.setSchema(catalog); } } /** * 在调用jdbc接口前处理业务中的catalog,schema,部分数据库(如mysql)业务系统与dbc标准可能不一致根据实际情况处理
* @param catalog 对于MySQL, 则对应相应的数据库, 对于Oracle来说, 则是对应相应的数据库实例, 可以不填, 也可以直接使用Connection的实例对象中的getCatalog()方法返回的值填充; * @param schema 可以理解为数据库的登录名, 而对于Oracle也可以理解成对该数据库操作的所有者的登录名。对于Oracle要特别注意, 其登陆名必须是大写, 不然的话是无法获取到相应的数据, 而MySQL则不做强制要求。 * @return String[] */ @Override public String[] correctSchemaFromJDBC(String catalog, String schema) { return new String[]{schema, null}; } public String insertHead(ConfigStore configs) { Boolean override = null; if(null != configs) { override = configs.override(); } if(null == override) { return "INSERT INTO "; }else{ if(override) { return "REPLACE INTO "; }else{ return "INSERT IGNORE INTO "; } } } public String insertFoot(ConfigStore configs, LinkedHashMap columns) { return ""; } /** * column[结果集封装]
(方法1)
* 元数据长度列 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta TypeMetadata * @return String */ @Override public String columnFieldLengthRefer(DataRuntime runtime, TypeMetadata meta) { return super.columnFieldLengthRefer(runtime, meta); } /** * column[结果集封装]
(方法1)
* 元数据数字有效位数列 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta TypeMetadata * @return String */ @Override public String columnFieldPrecisionRefer(DataRuntime runtime, TypeMetadata meta) { return super.columnFieldPrecisionRefer(runtime, meta); } /** * column[结果集封装]
(方法1)
* 元数据数字小数位数列 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param meta TypeMetadata * @return String */ @Override public String columnFieldScaleRefer(DataRuntime runtime, TypeMetadata meta) { return super.columnFieldScaleRefer(runtime, meta); } @Override public String value(DataRuntime runtime, Column column, SQL_BUILD_IN_VALUE value) { if(value == SQL_BUILD_IN_VALUE.CURRENT_DATETIME) { return "now()"; } if(value == SQL_BUILD_IN_VALUE.CURRENT_DATE) { return "curdate()"; } if(value == SQL_BUILD_IN_VALUE.CURRENT_TIME) { return "curtime()"; } if(value == SQL_BUILD_IN_VALUE.CURRENT_TIMESTAMP) { return "now()"; } return null; } /** * 拼接字符串 * @param runtime 运行环境主要包含驱动适配器 数据源或客户端 * @param args args * @return String */ @Override public String concat(DataRuntime runtime, String ... args) { return super.concatFun(runtime, args); } /** * 伪表 * @return String */ protected String dummy() { return super.dummy(); } }