文章目录
- 逆向工程配置与生成
- QBC查询风格
所谓的逆向工程是:根据数据库表逆向生成的Java的pojo类、SqlMapper.xml文件、以及mapper接口类等
要完成这个工作,需要借助别人写好的逆向工程插件。
虽然有点经典白学,但好像也没不白学
思考:使用这个插件的话,需要给这个插件配置哪些信息?
- pojo类名、包名以及生成的位置。
- SqlMapper.xml文件名以及生成的位置
- Mapper接口名以及生成的位置
- 连接数据库的信息
- 指定哪些表
- …
逆向工程配置与生成
pom.xml配置
<!--配置mybatis逆向工程的插件-->
<!--定制构建过程-->
<build>
<!--可以配置多个插件-->
<plugins>
<!--其中的一个插件:mybatis逆向工程插件-->
<plugin>
<!--插件的GAV坐标-->
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-maven-plugin</artifactId>
<version>1.4.1</version>
<!--允许覆盖-->
<configuration>
<overwrite>true</overwrite>
</configuration>
<!--插件的依赖-->
<dependencies>
<!--mysql驱动依赖-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.30</version>
</dependency>
</dependencies>
</plugin>
</plugins>
</build>
配置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>
<!--targetRuntime有两个值:-->
<!--MyBatis3Simple:生成的是基础版,只有基本的增删改查。-->
<!--MyBatis3:生成的是增强版,除本的增副改查之外还有复杂的增副改查。-->
<context id="DB2Tables" targetRuntime="MyBatis3">
<!--防止生成重复代码-->
<plugin type="org.mybatis.generator.plugins.UnmergeableXmlMappersPlugin"/>
<commentGenerator>
<!--是否去掉生成日期-->
<property name="suppressDate" value="true"/>
<!--是否去除注释-->
<property name="suppressAllComments" value="true"/>
</commentGenerator>
<!--连接数据库信息-->
<jdbcConnection driverClass="com.mysql.cj.jdbc.Driver"
connectionURL="jdbc:mysql://localhost:3306/demo"
userId="root"
password="root">
</jdbcConnection>
<!-- 生成pojo包名和位置-->
<javaModelGenerator targetPackage="com.powernode.mybatis.pojo"
targetProject="src/main/java">
<!-- 是否开启子包-->
<property name="enableSunPackages" value="true"/>
<!-- 是否去除字段名的前后空白-->
<property name="trimStrings" value="true"/>
</javaModelGenerator>
<!-- 生成SQL映射文件的包名和位置-->
<sqlMapGenerator targetPackage="com.powernode.mybatis.mapper"
targetProject="src/main/resources">
<!-- 是否开启了子包-->
<property name="enableSubPackages" value="true"/>
</sqlMapGenerator>
<!-- 生成Mapper接包名口的和位置-->
<javaClientGenerator
type="xmlMapper"
targetPackage="com.powernode.mybatis.mapper"
targetProject="src/main/java">
<property name="enableSubPackages" value="true"/>
</javaClientGenerator>
<!-- 表名和对应的实体类名-->
<table tableName="t_car" domainObjectName="Car"/>
</context>
</generatorConfiguration>
在配置完之后,只要老铁双击六六六就可以搭建起来了
QBC查询风格
在成功创建之后会发现pojo里面有一个CarExample,这玩意是为了来封装的
QBC风格:Query By Criteria 一种查询方式,比较面向对象,看不到sql语句。
@Test
public void test(){
SqlSession sqlSession = SqlSessionUtil.openSession();
CarMapper mapper = sqlSession.getMapper(CarMapper.class);
CarExample carExample = new CarExample();
carExample.createCriteria().andBrandEqualTo("阿巴阿巴");
carExample.or().andCarTypeEqualTo("燃油车");
sqlSession.close();
}