Инструмент обратной генерации Mybatis_generator
эффект
- генерировать
pojo
класс сущности - генерировать
XXXmapper.java
- генерировать
XXXmapper.xml
Обратный проект сборки
адрес проекта
Файл конфигурации GeneratorConfig.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE generatorConfiguration
PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
"http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
<generatorConfiguration>
<context id="MysqlContext" targetRuntime="MyBatis3Simple" defaultModelType="flat">
<property name="beginningDelimiter" value="`"/>
<property name="endingDelimiter" value="`"/>
<!-- 通用mapper所在目录 -->
<plugin type="tk.mybatis.mapper.generator.MapperPlugin">
<property name="mappers" value="com.icoding.my.mapper.MyMapper"/>
</plugin>
<jdbcConnection driverClass="com.mysql.jdbc.Driver"
connectionURL="jdbc:mysql://localhost:3306/mall-dev"
userId="root"
password="root">
</jdbcConnection>
<!-- 对应生成的pojo所在包 -->
<javaModelGenerator targetPackage="com.icoding.pojo" targetProject="src/main/java"/>
<!-- 对应生成的mapper所在目录 -->
<sqlMapGenerator targetPackage="mapper" targetProject="src/main/resources"/>
<!-- 配置mapper对应的java映射 -->
<javaClientGenerator targetPackage="com.icoding.mapper" targetProject="src/main/java" type="XMLMAPPER"/>
<!-- 数据库表 -->
<table tableName="carousel"></table>
<table tableName="category"></table>
<table tableName="items"></table>
<table tableName="items_comments"></table>
<table tableName="items_img"></table>
<table tableName="items_param"></table>
<table tableName="items_spec"></table>
<table tableName="order_items"></table>
<table tableName="order_status"></table>
<table tableName="orders"></table>
<table tableName="user_address"></table>
<table tableName="users"></table>
</context>
</generatorConfiguration>
Класс инструментов обратной генерации кода
public class GeneratorDisplay {
public void generator() throws Exception {
List<String> warnings = new ArrayList<String>();
boolean overwrite = true;
//指定 逆向工程配置文件
File configFile = new File("generatorConfig.xml");
ConfigurationParser cp = new ConfigurationParser(warnings);
Configuration config = cp.parseConfiguration(configFile);
DefaultShellCallback callback = new DefaultShellCallback(overwrite);
MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config,
callback, warnings);
myBatisGenerator.generate(null);
}
public static void main(String[] args) throws Exception {
try {
GeneratorDisplay generatorSqlmap = new GeneratorDisplay();
generatorSqlmap.generator();
} catch (Exception e) {
e.printStackTrace();
}
}
}
Конфигурация эталонного проекта
Внедрить универсальный инструмент сопоставления в pom
<!-- 通用mapper 逆向工具 -->
<dependency>
<groupId>tk.mybatis</groupId>
<artifactId>mapper-spring-boot-starter</artifactId>
<version>2.1.5</version>
</dependency>
существуетapplication.yml
Введите общую конфигурацию картографа в
#############################################################
#
# mybatis mapper 配置
#
#############################################################
# 通用mapper配置
mapper:
mappers: com.icoding.my.mapper.MyMapper
not-empty: false # 在进行数据库操作的时候,判断表达式 username != null, 在sql后追加 username != ''
identity: MYSQL
представлятьMyMapper
класс интерфейса (Общие методы работы с базой данных CRUD)
/**
* 继承自己的MyMapper
*/
public interface MyMapper<T> extends Mapper<T>, MySqlMapper<T> {
}
Первый взглядMyMapper
Унаследованный родительский класс, например:
public interface MyMapper<T> extends Mapper<T>, MySqlMapper<T>
Здесь есть два родительских класса,Mapper<T>
, MySqlMapper<T>
, смотрите исходники отдельно
MySqlMapper
public interface MySqlMapper<T> extends
InsertListMapper<T>,
InsertUseGeneratedKeysMapper<T>
Этот класс наследует два маппера, что видно из названия класса для операций вставки в БД.Эти два класса содержат следующие методы:
имя метода | действовать | Примечание |
---|---|---|
insertList(list) | Пакетная вставка базы данных | Первичный ключ необходимо увеличить |
InsertUseGeneratedKeysMapper(record) | Вставить данные таблицы | Первичный ключ необходимо увеличить |
В традиционной JavaWeb-разработке эти два метода не представляют проблемы, но в распределенном случае необходимо разработать глобально уникальный распределенный первичный ключ, и эти два метода в настоящее время использовать нельзя.
Mapper
public interface Mapper<T> extends
BaseMapper<T>,
ExampleMapper<T>,
RowBoundsMapper<T>,
Marker
Давайте посмотрим на методы в каждом родительском классе отдельно.
- BaseMapper
-
ExampleMapper
Example
Классы используются для предоставления пользователям настраиваемых условий, то естьwhere
условный
-
RowBoundsMapper
для пагинации.