Mybatis之逆向工程

Mybatis之逆向工程

一 MBG概述

MyBatis Generator: 简称MBG,是一个专门为MyBatis框架使用者定制的代码生成器,可以快速的根据表生成对应的 映射文件,接口,以及bean类。支持基本的增删 改查,以及QBC风格的条件查询。但是表连接、 存储过程等这些复杂sql的定义需要我们手工编写 。

官方文档地址:http://www.mybatis.org/generator

官方工程地址:https://github.com/mybatis/generator/releases

二 使用MBG

  1. 使用步骤
    (1)pom文件引入依赖和插件
    (2)编写MBG配置文件
    ① jdbcConnection配置数据库连接信息
    ② javaModelGenerator配置javaBean的生成策略
    ③ sqlMapGenerator 配置sql映射文件生成策略
    ④ javaClientGenerator配置Mapper接口的生成策略
    ⑤ )table 配置要逆向解析的数据表 tableName:表名; domainObjectName:对应的javaBean名
    (3)运行代码生成器生成代码
    注意:Context标签 targetRuntime=“MyBatis3“可以生成带条件的增删改查 targetRuntime=“MyBatis3Simple“可以生成基本的增删改查 如果再次生成,建议将之前生成的数据删除,避免xml向后追加内容出现的问题。
  2. 具体实现
    (1)pom文件
<dependency>
    <groupId>org.mybatis.generator</groupId>
    <artifactId>mybatis-generator</artifactId>
    <version>1.4.0</version>
</dependency>
<dependency>
    <groupId>org.mybatis.generator</groupId>
    <artifactId>mybatis-generator-maven-plugin</artifactId>
    <version>1.4.0</version>
</dependency>

(2)配置文件mbg.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>
	<!-- mybatis-generator:generate -->
	<context id="atguiguTables" targetRuntime="MyBatis3">
		<commentGenerator>
			<!-- 是否去除自动生成的注释 true:是;false:否 -->
			<property name="suppressAllComments" value="true" />
		</commentGenerator>

		<!--数据库连接的信息:驱动类、连接地址、用户名、密码 -->
		<jdbcConnection 
			driverClass="com.mysql.jdbc.Driver"
			connectionURL="jdbc:mysql://localhost:3306/project_crowd" 
			userId="root"
			password="admin">
		</jdbcConnection>

		<!-- 默认false,把JDBC DECIMAL 和 NUMERIC 类型解析为 Integer,为 true时把JDBC DECIMAL 
			和 NUMERIC 类型解析为java.math.BigDecimal -->
		<javaTypeResolver>
			<property name="forceBigDecimals" value="false" />
		</javaTypeResolver>

		<!-- targetProject:生成Entity类的路径 -->
		<javaModelGenerator targetProject=".\src\main\java"
			targetPackage="com.atguigu.crowd.entity">
			<!-- enableSubPackages:是否让schema作为包的后缀 -->
			<property name="enableSubPackages" value="false" />
			<!-- 从数据库返回的值被清理前后的空格 -->
			<property name="trimStrings" value="true" />
		</javaModelGenerator>

		<!-- targetProject:XxxMapper.xml映射文件生成的路径 -->
		<sqlMapGenerator targetProject=".\src\main\java"
			targetPackage="com.atguigu.crowd.mapper">
			<!-- enableSubPackages:是否让schema作为包的后缀 -->
			<property name="enableSubPackages" value="false" />
		</sqlMapGenerator>

		<!-- targetPackage:Mapper接口生成的位置 -->
		<javaClientGenerator type="XMLMAPPER"
			targetProject=".\src\main\java"
			targetPackage="com.atguigu.crowd.mapper">
			<!-- enableSubPackages:是否让schema作为包的后缀 -->
			<property name="enableSubPackages" value="false" />
		</javaClientGenerator>

		<!-- 数据库表名字和我们的entity类对应的映射指定 -->
		<table tableName="t_order" domainObjectName="Order" />
	</context>
</generatorConfiguration>

(3)生成器代码

public static void main(String[] args) throws Exception { 
	List<String> warnings = new ArrayList<String>(); 
	boolean overwrite = true; 
	File configFile = new File("mbg.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); 
}

三 测试

测试查询:QBC风格的带条件查询

@Test 
public void test01(){ 
	SqlSession openSession = build.openSession(); 
	DeptMapper mapper = openSession.getMapper(DeptMapper.class); 
	DeptExample example = new DeptExample(); 
	//所有的条件都在example中封装 
	Criteria criteria = example.createCriteria(); 
	//select id, deptName, locAdd from tbl_dept WHERE 
	//( deptName like ? and id > ? ) 
	criteria.andDeptnameLike("%部%"); 
	criteria.andIdGreaterThan(2); 
	List<Dept> list = mapper.selectByExample(example); 
	for (Dept dept : list) { 
	System. out .println(dept); 
	} 
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值