Инструмент обратной генерации базы данных генератор mybatis

MyBatis
Инструмент обратной генерации базы данных генератор mybatis

Инструмент обратной генерации Mybatis_generator

эффект

  • генерироватьpojoкласс сущности
  • генерироватьXXXmapper.java
  • генерироватьXXXmapper.xml

Обратный проект сборки

адрес проекта

mybatis-generator-for-icoding

Файл конфигурации 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

    для пагинации.