TableInfo.java 3.37 KB
   1
   2
   3
   4
   5
   6
   7
   8
   9
  10
  11
  12
  13
  14
  15
  16
  17
  18
  19
  20
  21
  22
  23
  24
  25
  26
  27
  28
  29
  30
  31
  32
  33
  34
  35
  36
  37
  38
  39
  40
  41
  42
  43
  44
  45
  46
  47
  48
  49
  50
  51
  52
  53
  54
  55
  56
  57
  58
  59
  60
  61
  62
  63
  64
  65
  66
  67
  68
  69
  70
  71
  72
  73
  74
  75
  76
  77
  78
  79
  80
  81
  82
  83
  84
  85
  86
  87
  88
  89
  90
  91
  92
  93
  94
  95
  96
  97
  98
  99
 100
 101
 102
 103
 104
 105
 106
 107
 108
 109
 110
 111
 112
 113
 114
 115
 116
 117
 118
 119
 120
 121
 122
 123
 124
 125
 126
 127
 128
 129
 130
 131
 132
 133
 134
 135
 136
 137
 138
 139
 140
 141
 142
 143
 144
 145
 146
 147
 148
 149
 150
 151
 152
 153
 154
 155
 156
 157
 158
 159
 160
 161
 162
 163
 164
 165
 166
 167
 168
 169
 170
 171
 172
 173
 174
/**
* Copyright (c) 2011-2014, hubin (jobob@qq.com).
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not
* use this file except in compliance with the License. You may obtain a copy of
* the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations under
* the License.
*/
package com.baomidou.mybatisplus.entity;

import java.util.List;

import org.apache.ibatis.session.Configuration;

import com.baomidou.mybatisplus.enums.IdType;
import com.baomidou.mybatisplus.exceptions.MybatisPlusException;

/**
* <p>
* 数据库表反射信息
* </p>
*
* @author hubin
* @Date 2016-01-23
*/
public class TableInfo {

/**
* 表主键ID 类型
*/
private IdType idType;

/**
* 表名称
*/
private String tableName;

/**
* 表映射结果集
*/
private String resultMap;

/**
* <p>
* 主键是否有存在字段名与属性名关联
* </p>
* true , false
*/
private boolean keyRelated = false;

/**
* 表主键ID 属性名
*/
private String keyProperty;

/**
* 表主键ID 字段名
*/
private String keyColumn;

/**
* 表字段信息列表
*/
private List<TableFieldInfo> fieldList;

/**
* 命名空间
*/
private String currentNamespace;
/**
* MybatisConfiguration 标记 (Configuration内存地址值)
*/
private String configMark;

/**
* <p>
* 获得注入的 SQL Statement
* </p>
*
* @param sqlMethod
* MybatisPlus 支持 SQL 方法
* @return
*/
public String getSqlStatement(String sqlMethod) {
StringBuffer statement = new StringBuffer();
statement.append(currentNamespace);
statement.append(".");
statement.append(sqlMethod);
return statement.toString();
}

public IdType getIdType() {
return idType;
}

public void setIdType(IdType idType) {
this.idType = idType;
}

public String getTableName() {
return tableName;
}

public void setTableName(String tableName) {
this.tableName = tableName;
}

public String getResultMap() {
return resultMap;
}

public void setResultMap(String resultMap) {
this.resultMap = resultMap;
}

public boolean isKeyRelated() {
return keyRelated;
}

public void setKeyRelated(boolean keyRelated) {
this.keyRelated = keyRelated;
}

public String getKeyProperty() {
return keyProperty;
}

public void setKeyProperty(String keyProperty) {
this.keyProperty = keyProperty;
}

public String getKeyColumn() {
return keyColumn;
}

public void setKeyColumn(String keyColumn) {
this.keyColumn = keyColumn;
}

public List<TableFieldInfo> getFieldList() {
return fieldList;
}

public void setFieldList(List<TableFieldInfo> fieldList) {
this.fieldList = fieldList;
}

public String getCurrentNamespace() {
return currentNamespace;
}

public void setCurrentNamespace(String currentNamespace) {
this.currentNamespace = currentNamespace;
}

public String getConfigMark() {
return configMark;
}

public void setConfigMark(Configuration configuration) {
if (configuration == null) {
throw new MybatisPlusException("Error: You need Initialize MybatisConfiguration !");
}
this.configMark = configuration.toString();
}

}