该项目是mybatis-generator-core 1.3.5 进行自定义注解生成的修改,
mybatis-generator-core 1.3.5官方下载地址,
主要添加中文注释信息,详细修改内容如下:
1.生成model对象的注释信息
2.get/set方法的注释信息
3.类注释信息
4.增删改查条件的注释信息
5.生成的代码符合阿里规范
6.批量增加、修改的操作
在设计数据库的时候,必须有主键
maven工程的打包,执行命令:clean install ,加入到本地仓库,生成“io\github\orange1438\mybatis-generator-core\1.3.5”包名(已经发布在maven中央仓库去了,可直接使用)
<build>
<defaultGoal>compile</defaultGoal>
<plugins>
<!-- 指定java版本-->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
<plugin>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-maven-plugin</artifactId>
<version>1.3.5</version>
<configuration>
<verbose>true</verbose>
<overwrite>true</overwrite>
<!-- 指定配置文件的路径,默认是在resources下-->
<configurationFile>${basedir}/src/main/resources/generator/generatorConfig.xml</configurationFile>
</configuration>
<executions>
<execution>
<id>Generate MyBatis Artifacts</id>
<goals>
<goal>generate</goal>
</goals>
</execution>
</executions>
<dependencies>
<dependency>
<groupId>io.github.orange1438</groupId>
<artifactId>mybatis-generator-core</artifactId>
<version>1.3.5</version>
</dependency>
</dependencies>
</plugin>
</plugins>
</build>
配置文件在该项目的资源文件里:resources/test/下的generatorConfig.properties文件和generatorConfig.xml文件;
我自己调试使用的是mysql数据库。想使用oracle数据,参考generatorConfigForOracle.xml文件里的配置(别忘了数据连接驱动jar包哦)
其中以下部分,我已经发布在maven中央仓库去了,可直接使用
<dependency>
groupId>io.github.orange1438</groupId>
<artifactId>mybatis-generator-core</artifactId>
<version>1.3.5</version>
</dependency>
1.剖析org.mybatis.generator.plugins.ToStringPlugin源码
2.剖析org.mybatis.generator.plugins.MapperConfigPlugin源码
3.剖析org.mybatis.generator.api.ShellRunner源码,Main入口
3.剖析org.mybatis.generator.config.xml.ConfigurationParser源码,配置解析器,用于对generatorConfig.xml配置文件的解析
4.剖析org.mybatis.generator.config.Context源码,封装元素内容
1.数据表的备注信息的添加:在FullyQualifiedTable类中添加remark字段,并在org.mybatis.generator.internal.db.DatabaseIntrospector类calculateIntrospectedTables方法,添加一段获取数据库备注的代码
//设置数据库表的备注信息
//start
Statement stmt = this.databaseMetaData.getConnection().createStatement();
ResultSet rs = stmt.executeQuery(
new StringBuilder()
.append("SHOW TABLE STATUS LIKE '")
.append(atn.getTableName())
.append("'")
.toString());
while (rs.next())
table.setRemark(rs.getString("COMMENT"));
closeResultSet(rs);
stmt.close();
//end
2..非model类Example的注释方法的添加,方法名addExampleClassComment(TopLevelClass topLevelClass)
3.重构部分org.mybatis.generator.codegen.mybatis3.IntrospectedTableMyBatis3Impl包里getGeneratedJavaFiles方法
4.详细中文注释的添加,入口包函数在org.mybatis.generator.api.ShellRunner
5.生成的中文注释信息可在修DefaultCommentGenerator类修改
6.增加MybatisServicePlugin:service层的代码生成,个人觉得不完美,因为业务会变,所以service层也会变,仅供学习参考
7.增加MapperPlugin:Mapper层有大量生成的重复方法,所以增加了统一继承IMapper接口实现
8.为IMapper接口加入批量插入数据的方法
9.删除ibatis2内容,并删除CaseInsensitiveLikePlugin插件(这个插件用来在XXXExample类中生成大小写敏感的LIKE方法插件本身用处不大,但是我们可以通过这个插件学习给XXXExample类添加额外的方法)),因此引用了ibatis2 10.为IMapper接口加入批量更新数据的方法
11.生成的代码符合阿里规范