目錄java
最近衰到了極點,SpringCloud有一個問題怎麼都解決不了,Oracle也有一個問題解決不了,Vue也有一個問題解決不了,如今Mybatis-generator也是網上搜了各類文章,結果發現,你搜一個知識點,網上的文章大多數都是抄襲的,如出一轍的文章處處是,我深深的懷疑這些複製粘貼的博主,傻逼?你複製個博客你就會了?複製博客本身不測試一下,全是錯的你知道嗎?mysql
還有,據說碼農教程這個傻逼網站在複製個人博客spring
我如今先測試一下,罵一下碼農教程是傻逼,我看看傻逼網站複製以前有沒有審覈,嘻嘻sql
書歸正傳,Mybatis-generator是什麼?在使用Mybatis的時候,dao接口,entity實體類,還有每一個實體類對應的xml都得本身寫吧,這其實也是工做量稍微大一點的事情,而咱們的插件Mybatis-generator就是自動生成這些代碼的數據庫
首先,新建一個過程,帶Maven就行,我新建了一個SpringBoot項目,pom.xml文件須要添加4個引用,以下apache
<dependencies> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.0.1</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.15</version> </dependency> <dependency> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-core</artifactId> <version>1.3.7</version> </dependency> </dependencies> <build> <plugins> <plugin> <!--Mybatis-generator插件,用於自動生成Mapper和POJO--> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-maven-plugin</artifactId> <version>1.3.2</version> <configuration> <!--配置文件的位置--> <configurationFile>src/main/resources/mybatis/mybatis-generator.xml</configurationFile> <verbose>true</verbose> <overwrite>true</overwrite> </configuration> <executions> <execution> <id>Generate MyBatis Artifacts</id> <goals> <goal>generate</goal> </goals> </execution> </executions> <dependencies> <dependency> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-core</artifactId> <version>1.3.2</version> </dependency> </dependencies> </plugin> </plugins> </build> </project>
我來解釋一下微信
數據庫建兩個表吧,我把個人貼出來,你想本身寫就本身寫,不想寫就複製個人mybatis
-- auto-generated definition create table user_info ( id int not null, name varchar(10) charset utf8 not null, gender varchar(10) charset utf8 null, age int null, phone varchar(20) null, register_mode varchar(20) null comment '註冊方式,例如手機註冊,微信註冊等', third_party_id varchar(64) null comment '第三方id,例如微信的id', constraint user_info_id_uindex unique (id) ); alter table user_info add primary key (id); -- auto-generated definition create table user_password ( id int not null primary key, encrypt_password varchar(128) not null, user_id int not null );
數據庫是miaosha,本身新建數據庫,而後執行上面的建立表的語句。數據暫時不須要app
最後一步了,這個xml位置你看着放,內容複製個人,我告訴你改哪裏dom
<?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> <!--數據庫驅動--> <classPathEntry location="D:\Java\apache-maven-3.5.4\repository\mysql\mysql-connector-java\8.0.15\mysql-connector-java-8.0.15.jar"/> <context id="context" targetRuntime="MyBatis3"> <commentGenerator> <property name="suppressDate" value="true"/> <property name="suppressAllComments" value="true"/> </commentGenerator> <!--數據庫連接地址帳號密碼--> <jdbcConnection driverClass="com.mysql.cj.jdbc.Driver" connectionURL="jdbc:mysql://localhost:3306/miaosha?serverTimezone=UTC" userId="root" password="123"> </jdbcConnection> <javaTypeResolver> <property name="forceBigDecimals" value="false"/> </javaTypeResolver> <!--生成Model類存放位置--> <javaModelGenerator targetPackage="com.miaosha.dataobject" targetProject="src/main/java"> <property name="enableSubPackages" value="true"/> <property name="trimStrings" value="true"/> </javaModelGenerator> <!--生成映射文件存放位置--> <sqlMapGenerator targetPackage="mybatis.mapper" targetProject="src/main/resources"> <property name="enableSubPackages" value="true"/> </sqlMapGenerator> <!--生成Dao類存放位置--> <javaClientGenerator type="XMLMAPPER" targetPackage="com.miaosha.dao" targetProject="src/main/java"> <property name="enableSubPackages" value="true"/> </javaClientGenerator> <!--生成對應表及類名--> <table tableName="user_info" domainObjectName="userDAO" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table> <table tableName="user_password" domainObjectName="userpasswordDAO" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table> </context> </generatorConfiguration>
須要改的地方:
這個很簡單,編輯配置,新建maven,而後輸入圖中的內容,直接運行便可
mybatis-generator:generate