MyBatis is an excellent persistence layer framework that supports customized SQL, stored procedures, and advanced mapping. MyBatis avoids almost all of the JDBC code and manual setting of parameters and fetching result sets. MyBatis can configure and map native information using simple XML or annotations to map interfaces and Java’s POJOs(Plain Ordinary Java Objects) to records in the database.
Two forms:
XML style type = “XMLMAPPER”
Annotation method type=”ANNOTATEDMAPPER”
VXML way
1.1 Add maven plugin to POM.xml
<! -- mybatis.generator start--> <plugin> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-maven-plugin</artifactId> <version>1.3.5</version> <dependencies> <dependency> <groupId> Mysql </groupId> <artifactId> mysql-connector-java</artifactId> <version> 5.1.39</version> </dependency> <dependency> < the groupId > org. Mybatis. The generator < / groupId > < artifactId > mybatis generator - core < / artifactId > < version > 1.3.5 < / version > </dependency> </dependencies> <executions> <execution> <id>Generate MyBatis Artifacts</id> <phase>package</phase> <goals> <goal>generate</goal> </goals> </execution> </executions> <configuration> <! -- Allow moving generated files --> <verbose>true</verbose> <! -- overwrite --> <overwrite>true</overwrite> <! - automatically generate configuration - > < configurationFile > SRC/main/resources/mybatis generator/mybatis - generator. XML < / configurationFile > </configuration> </plugin> <! -- mybatis.generator end-->Copy the code
Create mybatis-generator.xml under resources
<? The 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> <context id="DB2Tables" targetRuntime="MyBatis3"> <commentGenerator> <property name="suppressDate" value="true"/> <property name="suppressAllComments" value="true"/> </commentGenerator> <! - database link account password - > < jdbcConnection driverClass = ". Com. Mysql. JDBC Driver "connectionURL =" JDBC: mysql: / / localhost: 3306 / mytest" userId="toutou" password="*********"> </jdbcConnection> <javaTypeResolver> <property name="forceBigDecimals" value="false"/> </javaTypeResolver> <javaModelGenerator targetPackage="com.demo.pojo" targetProject="src/main/java"> <property name="enableSubPackages" value="false" /> <property name="trimStrings" value="true" /> </javaModelGenerator> <sqlMapGenerator targetPackage="mapper" targetProject="src/main/resources"> <property name="enableSubPackages" value="false" /> </sqlMapGenerator> <javaClientGenerator targetPackage="com.demo.dao" targetProject="src/main/java" type="XMLMAPPER"> <property name="enableSubPackages" value="false" /> </javaClientGenerator> <! <table tableName=" userDetails "domainObjectName=" userDetails" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table> </context> </generatorConfiguration>Copy the code
1.3 In Maven Project, double-click mybatis- Generator: Generate
1.4 update the application. The properties
The configuration file version is slightly more complex than the annotation version, the only difference between the two is the mapper layer processing is different, so the entity layer and control layer, database and so on are the same.
V Annotation method
In the previous article “SpringBoot(a) detailed explanation of Intellij IDEA build SpringBoot”, we use is mybatis annotated version, here is not to say more.
MyBatis 3 Annotation Example with @select, @insert, @update and @delete
Mybatis generator ANNOTATEDMAPPER and XMLMAPPER, with mybatis generator annotation, Replace the Type attribute in javaClientGenerator with type=”ANNOTATEDMAPPER”.
V Blog Summary
The annotated version is cleaner and clearer, with no XML files, and is recommended. Especially combined with SpringBoot, Springboot itself relative to the traditional SpringMVC project, is to configure words, so that the project is more concise.
About the author: Focus on basic platform project development. If you have any questions or suggestions, please feel free to comment! Copyright notice: The copyright of this article belongs to the author and the blog garden, welcome to reprint, but without the consent of the author must retain this statement, and give the original text link in a prominent place on the page of the article. For the record: all comments and messages will be answered as soon as possible. You are welcome to correct your mistakes and make progress together. Or direct private message I support the blogger: if you think the article is helpful to you, you can click on the lower right corner of the article [recommendation]. Your encouragement is the author to adhere to the original and continuous writing of the biggest power! \