mybatis-metamodel mybatis 元数据模型生成插件开源项目

我要开发同款
匿名用户2020年02月18日
129阅读
开发技术Java
所属分类数据库管理工具、数据库相关、数据库调整和优化
授权协议Apache

作品详情

mybatis-metamodel是mybatis-plus和tkmapper的元数据模型生成插件,目的是解决它们在复杂场景下自定义SQL时的紧耦合问题。

用途

我们都知道mybatis-plus和tkmapper开源项目是mybatis优秀的增强插件,它们通过重定义MappedStatement实现了通用增删改查。它们所提供的增删改查的功能,极大提高了开发者的开发效率。

但是,在一些复杂的应用场景下,它们的通用增删改查不能满足我们的开发需求,为了实现需求,需要通过它们内置的条件查询组件自定义查询语句。在这种复杂场景下,就无法避免使用字符串表示表名或者字段名,这在复杂的项目中如果修改了字段名,很容易造成后期运行时错误。

为了避免应用在运行时发生错误,本项目将在编译期提供数据库的元数据,可以帮助应用在编译期就感知原有数据库元数据的修改。

举个li'zi:   我们需要自定义SQL查询用户信息。引入本项目后,可以在编译期自动生成元数据模型UserInfo_.class,元数据模型里面包含每个tablefield的信息,除此之外,还可以通过MetaModelContext获取对应的表信息。

Mapper//根据example条件查询StringqueryUserName="hugo_1";ExampleuserInfoQueryExample=newExample(UserInfo.class);Example.Criteriacriteria=userInfoQueryExample.createCriteria();criteria.andEqualTo(UserInfo_.username.getColumn(),queryUserName);List<UserInfo>userInfosByQuery=userInfoMapper.selectByExample(userInfoQueryExample);Assert.assertEquals(1,userInfosByQuery.size());//获取table名StringtableName=metaModelContext.getTableName(UserInfo_.class);Assert.assertEquals("user_info",tableName);mybatis-plus //根据map查询//查询username为hugo_1的数据Map<String,Object>map=newHashMap<>();map.put(UserInfo_.username.getColumn(),"hugo_1");//获取元数据userInfo=userInfoMapper.selectByMap(map).get(0);//wrapper查询//查询address为中国的列表List<UserInfo>userList=userInfoMapper.selectList(    newQueryWrapper<UserInfo>().eq(UserInfo_.address.getColumn(),"中国"));//获取table名StringtableName=metaModelContext.getTableName(UserInfo_.class);支持特性mapper

支持MAPPER版本1.1.5+1.支持是否使用原语类型配置usePrimitiveType,默认为false,建议不要开启,没有意义2.支持配置useSimpleType,默认为true3.支持配置enumAsSimpleType4.支持数据库的catalog和schema配置5.支持全局字段转换方式style6.支持@Table注解7.支持@NameStyle注解8.支持@Transient、@Column、@ColumnType注解9.支持忽略static/transient修饰词的字段

mybatis-plus

支持mybatis-plus版本3.2.0+1.支持全局配置tableUnderline、capitalMode2.支持忽略static/transient修饰词的字段3.支持@TableName注解4.支持@TableId、@TableField注解

不支持特性mapper

1.不支持动态表名IDynamicTableName2.不支持方法上使用注解,即enableMethodAnnotation全局配置

TODO  mapper  

 

mybatis-plus  

1.支持配置keepGlobalFormat2.支持配置tablePrefix3.支持配置columnFormat4.支持配置propertyFormat

使用说明

参考下面的wikigitee

声明:本文仅代表作者观点,不代表本站立场。如果侵犯到您的合法权益,请联系我们删除侵权资源!如果遇到资源链接失效,请您通过评论或工单的方式通知管理员。未经允许,不得转载,本站所有资源文章禁止商业使用运营!
下载安装【程序员客栈】APP
实时对接需求、及时收发消息、丰富的开放项目需求、随时随地查看项目状态

评论