Mybatis-Plus代碼生成器初體驗

1.簡介 

MyBatis Plus 在 MyBatis 的基礎上只做增強不做改變,爲簡化開發、提高效率而生。

MyBatis Plus 的核心功能有:支持通用的 CRUD、代碼生成器與條件構造器。

2.引入依賴

	    <!-- mp 依賴 -->
		<dependency>
			<groupId>com.baomidou</groupId>
			<artifactId>mybatis-plus</artifactId>
			<version>2.3</version>
		</dependency>

		<!-- 代碼生成:MP -->
		<dependency>
			<groupId>com.baomidou</groupId>
			<artifactId>mybatis-plus-generator</artifactId>
			<version>3.1.2</version>
		</dependency>
		<!-- 代碼生成:模板引擎MybatisPlus默認使用的是velocity模版引 -->
		<dependency>
			<groupId>org.apache.velocity</groupId>
			<artifactId>velocity-engine-core</artifactId>
			<version>2.1</version>
		</dependency>

3.配置文件

package com.util;

import java.util.Collections;
import java.util.HashMap;
import java.util.Map;

import com.baomidou.mybatisplus.generator.AutoGenerator;
import com.baomidou.mybatisplus.generator.InjectionConfig;
import com.baomidou.mybatisplus.generator.config.DataSourceConfig;
import com.baomidou.mybatisplus.generator.config.FileOutConfig;
import com.baomidou.mybatisplus.generator.config.GlobalConfig;
import com.baomidou.mybatisplus.generator.config.PackageConfig;
import com.baomidou.mybatisplus.generator.config.StrategyConfig;
import com.baomidou.mybatisplus.generator.config.po.TableInfo;
import com.baomidou.mybatisplus.generator.config.rules.DbType;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;

/**
 * MP代碼生成工具
 * 
 * @author 鵬程萬裏
 * @date 2019年8月21日 下午3:23:32
 */
public class MpGenerator {
	public static void main(String[] args) {
		AutoGenerator mpg = new AutoGenerator();
		// 獲取項目路徑
		String basePath = System.getProperty("user.dir");
		// 設置數據源
		mpg.setDataSource(new DataSourceConfig().setDriverName("com.mysql.jdbc.Driver")
				// 設置數據庫類型
				.setDbType(DbType.MYSQL).setUsername("數據庫賬號").setPassword("數據庫密碼").setUrl("jdbc:mysql://數據庫地址:3306/數據庫名稱?useUnicode=true&useSSL=false&characterEncoding=utf8"));

		// 全局配置
		mpg.setGlobalConfig(new GlobalConfig()
				// 輸出目錄
				.setOutputDir(basePath + "/src/main/java")
				// 是否覆蓋
				.setFileOverride(true)
				// 開啓AR模式
				.setActiveRecord(true)
				// XML二級緩存
				.setEnableCache(false)
				// 生成ResultMap
				.setBaseResultMap(true)
				// 生成 sql片段
				.setBaseColumnList(true)
				// 自動打開生成後的文件夾
				.setOpen(false)
				// 所有文件的生成者
				.setAuthor("yangpengcheng")
				// 自定義文件命名,%s會自動填充表實體類名字
				.setMapperName("%sMapper").setXmlName("%sMapper").setServiceName("I%sService").setServiceImplName("%sServiceImpl").setControllerName("%sController"));

		// 策略配置
		mpg.setStrategy(new StrategyConfig()
				// 需要生成的表
				.setInclude("sys_school")
				// 實體類使用Lombok
				.setEntityLombokModel(true)
				// 表名生成策略,下劃線轉駝峯
				.setNaming(NamingStrategy.underline_to_camel)
				// 去掉數據前綴名稱(不用去前綴,該屬性可以忽略不寫)
				.setTablePrefix("sys_"));

		// 包配置
		mpg.setPackageInfo(new PackageConfig()
				// 基本包路徑
				.setParent("com")
				// 設置Controller包名
				.setController("web")
				// 設置entity包名
				.setEntity("model.po")
				// 設置Mapper包名
				.setMapper("dao")
				// 設置Service包名
				.setService("service")
				// 設置Service實現類包名
				.setServiceImpl("service.impl")
				// 設置Mapper.xml包名
				.setXml("mapper"));

		// 注入自定義配置
		mpg.setCfg(new InjectionConfig() {
			@Override
			public void initMap() {
				Map<String, Object> map = new HashMap<>(1);
				map.put("abc", this.getConfig().getGlobalConfig().getAuthor() + "-mp");
				this.setMap(map);
			}
		}.setFileOutConfigList(Collections.singletonList(new FileOutConfig("/templates/mapper.xml.vm") {
			// 自定義Mapper.xml輸出路徑
			@Override
			public String outputFile(TableInfo tableInfo) {
				return basePath + "/src/main/resources/com/mapper/" + tableInfo.getEntityName() + "Mapper.xml";
			}
		})));
		// 執行代碼自動生成
		mpg.execute();
	}
}

4.生成的service代碼查看

package com.service;

import com.model.po.School;
import com.baomidou.mybatisplus.service.IService;

/**
 * <p>
 *  服務類
 * </p>
 *
 * @author 鵬程萬裏
 * @since 2019-08-21
 */
public interface ISchoolService extends IService<School> {

}

SchoolService繼承了ServiceImpl,在ServiceImpl中就已經注入了SchoolMapper,所以,我們就不需要再次注入,在ServiceImpl中也幫我們提供了常用的CRUD方法,我們可以直接使用。

@Controller
@RequestMapping("/school")
public class SchoolController {
    @Autowired
    private ISchoolService service;

    public String select(){
        service.selectList(null);
        return null;
    }
}

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章