JShop简介:jshop是一套使用Java语言开发的B2C网店系统,致力于为个人和中小企业提供免费、好用的网店系统。
项目主页:http://git.oschina.net/dinguangx/jshop
在线演示:
- 前台: http://jshop.coding.io
- 后台: http://jshop.coding.io/manage/user/login (admin/123456)
mybatis-generator生成的代码文件主要有:
(1)mapper映射文件
(2)client(如果mybatis是ClientMapper接口类,而ibatis2则是DAO和DAOImpl)
(3)model:即与数据库字段一一对应的POJO
(4)model example
为这些代码文件提供的与数据库交互的方法有:
countByExample deleteByExample deleteByPrimaryKey insert insertSelective selectByExampleWithBLOBs selectByExampleWithoutBLOBs selectByPrimaryKey updateByExampleSelective updateByExampleWithBLOBs updateByExampleWithoutBLOBs updateByPrimaryKeySelective updateByPrimaryKeyWithBLOBs updateByPrimaryKeyWithoutBLOBs
围绕这几类的代码文件,mybatis generaotr提供了高度可定制化的扩展点,如对这些文件如何生成注释提供了CommentGenerator,控制整个代码生成过程的Plugin等。
jshop在集成mybatis gerarator时,主要针对实际的使用情况,定制了代码注释生成器和控制生成哪些方法的Plugin
(1) CommentGenerator定制
CommentGenerator对代码中的注释生成过程进行拦截和扩展,注释的类型包括文档注释,属性注释,方法注释,日期注释,setter/getter注释等。实际上,大部分的注释都是无意义的,仅仅为了表明生成的时间和标示是自动生成的。所以jshop中对comment generator进行定制,只保留model bean中的field注释,取的是字段的comment,其他注释全部去除,如下:
具体定制的代码见CommentGeneratorExt
生成的model文件示例如下:
public class ArticleCatalog implements Serializable { /** ID */ private Integer id; /** 分类名称 */ private String name; /** 父级ID */ private Integer pid; /** 顺序 */ private Integer order; /** 类型 */ private String type; /** 分类编码 */ private String code; private static final long serialVersionUID = 1L; public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name == null ? null : name.trim(); } public Integer getPid() { return pid; } public void setPid(Integer pid) { this.pid = pid; } public Integer getOrder() { return order; } public void setOrder(Integer order) { this.order = order; } public String getType() { return type; } public void setType(String type) { this.type = type == null ? null : type.trim(); } public String getCode() { return code; } public void setCode(String code) { this.code = code == null ? null : code.trim(); } }
(2) Plugin定制-生成的method取舍
为了减少可能出现的代码bug,去除了updateByExample,deleteByExample, updateByExampleSelective和deleteByExampleSelective相关的方法,因为这几个方法会根据条件批量更新数据库,容易引入潜在的bug,保留updateByPrimaryKey和deleteByPrimaryKey进行数据库更新操作。
具体代码见JshopCustomPlugin
(3) Plugin扩展-mapper代码生成的问题
默认情况下,不删除原来已经生成过的代码文件时,dao,model文件可以在再次生成时被覆盖,而mapper文件则不会,所以对plguin进行扩展,可以在再次生成代码文件时,将原mapper文件覆盖掉。
/** * mapper文件可被重写的插件,默认情况下,重新生成代码时,mapper文件不会被覆盖 * 通过参数mapperOverwrite决定是否覆盖mapper文件,该值默认为true */ public class MapperFileOverwritePlugin extends PluginAdapter { @Override public boolean validate(List<String> warnings) { return true; } private boolean mapperOverwrite = true; @Override public void setProperties(Properties properties) { super.setProperties(properties); mapperOverwrite = Boolean.valueOf(properties.getProperty("mapperOverwrite", String.valueOf(mapperOverwrite))); } @Override public boolean sqlMapGenerated(GeneratedXmlFile sqlMap, IntrospectedTable introspectedTable) { if(mapperOverwrite){ try { Field mergedField = GeneratedXmlFile.class.getDeclaredField("isMergeable"); mergedField.setAccessible(true); mergedField.setBoolean(sqlMap, false); return true; } catch (Exception e){ e.printStackTrace(); } } return super.sqlMapGenerated(sqlMap, introspectedTable); } }
jshop自动生成代码规范:
所有生成的代码位于src/main/gen目录,如果需要扩展model或client文件,则在src/main/java下新建一个继承于生成的model或client类的新类;如果需要扩展mapper文件,则在src/main/resources/mapper/ext中新建mapper文件。以便于在数据库有变动时,可以再次调用代码生成程序重新生成相关的文件。