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測試 --> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.13.2</version> <scope>test</scope> </dependency> <!-- MySQL驅(qū)動 --> <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ān)配置 --> <build> <pluginManagement> </pluginManagement> <plugins> <!-- 具體插件,逆向工程的操作是以構(gòu)建過程中插件形式出現(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ù)庫連接池 --> <dependency> <groupId>com.mchange</groupId> <artifactId>c3p0</artifactId> <version>0.9.2</version> </dependency> <!-- MySQL驅(qū)動 --> <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(清新簡潔版) MyBatis3: 生成帶條件的CRUD(奢華尊享版) --> <context id="DB2Tables" targetRuntime="MyBatis3Simple"> <!-- 數(shù)據(jù)庫的連接信息 --> <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è)置為*號,可以對應(yīng)所有表,此時不寫domainObjectName --> <!-- domainObjectName屬性指定生成出來的實體類的類名 --> <table tableName="t_user" domainObjectName="User"/> <table tableName="t_book" domainObjectName="Book"/> </context> </generatorConfiguration>
如果出現(xiàn)報錯:Exception getting JDBC Driver
,可能是pom.xml中,數(shù)據(jù)庫驅(qū)動配置不一致。
注意:
mac 、liunx 的路徑和 windows 的路徑不一樣
找到idea 旁邊的maven
結(jié)果:
MyBatis Generator代碼生成器自動生成.java.1文件,如果想取消
解決辦法:
在工程項目pom.xml中改為允許覆蓋生成文件:
<configuration> <!--允許覆蓋生成的文件--> <overwrite>true</overwrite> </configuration>
QBC
查詢
selectByExample
:按條件查詢,需要傳入一個example對象或者null;如果傳入一個null,則表示沒有條件,也就是查詢所有數(shù)據(jù)example.createCriteria().xxx
:創(chuàng)建條件對象,通過andXXX方法為SQL添加查詢添加,每個條件之間是and關(guān)系example.or().xxx
:將之前添加的條件通過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
:通過主鍵進(jìn)行數(shù)據(jù)修改,如果某一個值為null,也會將對應(yīng)的字段改為nullmapper.updateByPrimaryKey(new Emp(1,"admin",22,null,"456@qq.com",3));
就是說 為null 值也會替換它
- updateByPrimaryKeySelective()`:通過主鍵進(jìn)行選擇性數(shù)據(jù)修改,如果某個值為null,則不修改這個字段
mapper.updateByPrimaryKeySelective(new Emp(2,"admin2",22,null,"456@qq.com",3));
當(dāng)有null 值想插入時,原理的值不是null 這不會變成null。
到此這篇關(guān)于Mybatis創(chuàng)建逆向工程的步驟的文章就介紹到這了,更多相關(guān)Mybatis創(chuàng)建逆向工程內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
RocketMQ源碼分析之Broker過期消息清理機(jī)制
這篇文章主要為大家介紹了RocketMQ源碼分析之Broker過期消息清理機(jī)制示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05Springboot并發(fā)調(diào)優(yōu)之大事務(wù)和長連接
這篇文章主要介紹了Springboot并發(fā)調(diào)優(yōu)之大事務(wù)和長連接,重點分享長事務(wù)以及長連接導(dǎo)致的并發(fā)排查和優(yōu)化思路和示例,具有一定的參考價值,感興趣的可以了解一下2022-05-05SpringBoot?Knife4j框架&Knife4j的顯示內(nèi)容的配置方式
Knife4j框架是基于Swagger2開發(fā)的在線API文檔生成工具,主要功能包括自動生成API文檔、接口文檔展示、接口測試工具、接口權(quán)限控制和在線調(diào)試,該框架支持通過注解自動生成詳細(xì)的接口文檔,開發(fā)者可以直接在文檔界面進(jìn)行接口測試和調(diào)試2024-09-09Java將字符串String轉(zhuǎn)換為整型Int的兩種方式
這篇文章主要介紹了Java如何將字符串String轉(zhuǎn)換為整型Int,在 Java 中要將 String 類型轉(zhuǎn)化為 int 類型時,需要使用 Integer 類中的 parseInt() 方法或者 valueOf() 方法進(jìn)行轉(zhuǎn)換,本文通過實例代碼給大家詳細(xì)講解,需要的朋友可以參考下2023-04-04