Mybatis創(chuàng)建逆向工程的步驟
添加依賴和插件
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.example</groupId>
<artifactId>mybatis</artifactId>
<version>1.0-SNAPSHOT</version>
<properties>
<maven.compiler.source>17</maven.compiler.source>
<maven.compiler.target>17</maven.compiler.target>
</properties>
<dependencies>
<!-- MyBatis核心依賴包 -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.9</version>
</dependency>
<!-- junit測(cè)試 -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.13.2</version>
<scope>test</scope>
</dependency>
<!-- MySQL驅(qū)動(dòng) -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.27</version>
</dependency>
<!-- log4j日志 -->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
</dependencies>
<!-- 控制Maven在構(gòu)建過(guò)程中相關(guān)配置 -->
<build>
<pluginManagement> </pluginManagement>
<plugins>
<!-- 具體插件,逆向工程的操作是以構(gòu)建過(guò)程中插件形式出現(xiàn)的 -->
<plugin>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-maven-plugin</artifactId>
<version>1.3.0</version>
<!-- 插件的依賴 -->
<dependencies>
<!-- 逆向工程的核心依賴 -->
<dependency>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-core</artifactId>
<version>1.3.2</version>
</dependency>
<!-- 數(shù)據(jù)庫(kù)連接池 -->
<dependency>
<groupId>com.mchange</groupId>
<artifactId>c3p0</artifactId>
<version>0.9.2</version>
</dependency>
<!-- MySQL驅(qū)動(dòng) -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.27</version>
</dependency>
</dependencies>
</plugin>
</plugins>
</build>
</project>
創(chuàng)建MyBatis的核心配置文件
在resources下面寫配置文件
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<properties resource="jdbc.properties"/>
<typeAliases>
<package name=""/>
</typeAliases>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="${jdbc.driver}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
</dataSource>
</environment>
</environments>
<mappers>
<package name=""/>
</mappers>
</configuration>
創(chuàng)建逆向工程的配置文件
文件名必須是: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: 執(zhí)行生成的逆向工程的版本
MyBatis3Simple: 生成基本的CRUD(清新簡(jiǎn)潔版)
MyBatis3: 生成帶條件的CRUD(奢華尊享版)
-->
<context id="DB2Tables" targetRuntime="MyBatis3Simple">
<!-- 數(shù)據(jù)庫(kù)的連接信息 -->
<jdbcConnection driverClass="com.mysql.cj.jdbc.Driver"
connectionURL="jdbc:mysql://localhost:3306/bookdb"
userId="root"
password="Thm123456!">
</jdbcConnection>
<!-- javaBean的生成策略-->
<javaModelGenerator targetPackage="com.mybatis.pojo" targetProject="./src/main/java">
<property name="enableSubPackages" value="true" />
<property name="trimStrings" value="true" />
</javaModelGenerator>
<!-- SQL映射文件的生成策略 -->
<sqlMapGenerator targetPackage="com.mybatis.mapper"
targetProject="./src/main/resources">
<property name="enableSubPackages" value="true" />
</sqlMapGenerator>
<!-- Mapper接口的生成策略 -->
<javaClientGenerator type="XMLMAPPER"
targetPackage="com.mybatis.mapper" targetProject="./src/main/java">
<property name="enableSubPackages" value="true" />
</javaClientGenerator>
<!-- 逆向分析的表 -->
<!-- tableName設(shè)置為*號(hào),可以對(duì)應(yīng)所有表,此時(shí)不寫domainObjectName -->
<!-- domainObjectName屬性指定生成出來(lái)的實(shí)體類的類名 -->
<table tableName="t_user" domainObjectName="User"/>
<table tableName="t_book" domainObjectName="Book"/>
</context>
</generatorConfiguration>
如果出現(xiàn)報(bào)錯(cuò):Exception getting JDBC Driver,可能是pom.xml中,數(shù)據(jù)庫(kù)驅(qū)動(dòng)配置不一致。
注意:
mac 、liunx 的路徑和 windows 的路徑不一樣
找到idea 旁邊的maven

結(jié)果:

MyBatis Generator代碼生成器自動(dòng)生成.java.1文件,如果想取消
解決辦法:
在工程項(xiàng)目pom.xml中改為允許覆蓋生成文件:
<configuration>
<!--允許覆蓋生成的文件-->
<overwrite>true</overwrite>
</configuration>
QBC
查詢
selectByExample:按條件查詢,需要傳入一個(gè)example對(duì)象或者null;如果傳入一個(gè)null,則表示沒(méi)有條件,也就是查詢所有數(shù)據(jù)example.createCriteria().xxx:創(chuàng)建條件對(duì)象,通過(guò)andXXX方法為SQL添加查詢添加,每個(gè)條件之間是and關(guān)系example.or().xxx:將之前添加的條件通過(guò)or拼接其他條件
@Test public void testMBG() throws IOException {
InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(is);
SqlSession sqlSession = sqlSessionFactory.openSession(true);
EmpMapper mapper = sqlSession.getMapper(EmpMapper.class);
EmpExample example = new EmpExample();
//名字為張三,且年齡大于等于20
example.createCriteria().andEmpNameEqualTo("張三").andAgeGreaterThanOrEqualTo(20);
//或者did不為空
example.or().andDidIsNotNull();
List<Emp> emps = mapper.selectByExample(example);
emps.forEach(System.out::println);
}
增改
updateByPrimaryKey:通過(guò)主鍵進(jìn)行數(shù)據(jù)修改,如果某一個(gè)值為null,也會(huì)將對(duì)應(yīng)的字段改為nullmapper.updateByPrimaryKey(new Emp(1,"admin",22,null,"456@qq.com",3));
就是說(shuō) 為null 值也會(huì)替換它
- updateByPrimaryKeySelective()`:通過(guò)主鍵進(jìn)行選擇性數(shù)據(jù)修改,如果某個(gè)值為null,則不修改這個(gè)字段
mapper.updateByPrimaryKeySelective(new Emp(2,"admin2",22,null,"456@qq.com",3));
當(dāng)有null 值想插入時(shí),原理的值不是null 這不會(huì)變成null。
到此這篇關(guān)于Mybatis創(chuàng)建逆向工程的步驟的文章就介紹到這了,更多相關(guān)Mybatis創(chuàng)建逆向工程內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
RocketMQ源碼分析之Broker過(guò)期消息清理機(jī)制
這篇文章主要為大家介紹了RocketMQ源碼分析之Broker過(guò)期消息清理機(jī)制示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05
Spring前后端跨域請(qǐng)求設(shè)置代碼實(shí)例
這篇文章主要介紹了Spring前后端跨域請(qǐng)求設(shè)置代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07
Springboot并發(fā)調(diào)優(yōu)之大事務(wù)和長(zhǎng)連接
這篇文章主要介紹了Springboot并發(fā)調(diào)優(yōu)之大事務(wù)和長(zhǎng)連接,重點(diǎn)分享長(zhǎng)事務(wù)以及長(zhǎng)連接導(dǎo)致的并發(fā)排查和優(yōu)化思路和示例,具有一定的參考價(jià)值,感興趣的可以了解一下2022-05-05
SpringBoot?Knife4j框架&Knife4j的顯示內(nèi)容的配置方式
Knife4j框架是基于Swagger2開(kāi)發(fā)的在線API文檔生成工具,主要功能包括自動(dòng)生成API文檔、接口文檔展示、接口測(cè)試工具、接口權(quán)限控制和在線調(diào)試,該框架支持通過(guò)注解自動(dòng)生成詳細(xì)的接口文檔,開(kāi)發(fā)者可以直接在文檔界面進(jìn)行接口測(cè)試和調(diào)試2024-09-09
Java將字符串String轉(zhuǎn)換為整型Int的兩種方式
這篇文章主要介紹了Java如何將字符串String轉(zhuǎn)換為整型Int,在 Java 中要將 String 類型轉(zhuǎn)化為 int 類型時(shí),需要使用 Integer 類中的 parseInt() 方法或者 valueOf() 方法進(jìn)行轉(zhuǎn)換,本文通過(guò)實(shí)例代碼給大家詳細(xì)講解,需要的朋友可以參考下2023-04-04
idea將項(xiàng)目上傳到Gitee的圖文過(guò)程
這篇文章主要介紹了idea將項(xiàng)目上傳到Gitee上,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-08-08

