- 代码生成器添加达梦数据库支持
- 修复多主键查询表字段SQL的Bug
- 新增 updateWrapper 尝试更新,否继续执行saveOrUpdate(T)方法
- 代码生成器 pg 增加 numeric instant 类型支持
- 修复InjectionConfig不存在时无法生成代码的问题
- fix: #1386(github) 逻辑删除字段为Date类型并且非删除数据日期为null
- 升级依赖 mybatis 版本为 3.5.2
- 升级依赖 jsqlparser 版本为 2.1
- 应 EasyScheduler 计划提交 Apache 孵化请求移除 996NPL 协议限制
- 调整 SQL 移除 SET 部分 Github/1460
- 移除 SqlMethod 枚举 UPDATE_ALL_COLUMN_BY_ID 属性,推荐使用 AlwaysUpdateSomeColumnById 套
- fix: #1412(github) github:mybatis-plus-generator can't support oracle
- fix: github 1380
- 移除全局配置的 dbType 和 columnLike
- 移除 fieldStrategy, 使用上个版本新增的三个替代
- 移除 PerformanceInterceptor 相关, 建议使用 p6spy
- 移除 el 拆分为 jdbcType typeHandler 等具体属性
- 升级 gradle-5.5.1,lombok-1.18.4
- 当selectStatement.getSelectBody()的类型为SetOperationList
- 移除 GlobalConfig#sqlParserCache 属性,移除 LogicSqlInjector, OrderItem 新增2个快捷生成的method, page 新增一个入参是 List 的 addOrder method
- Nested 接口个别入参是
Function<Param, Param> func
的method,入参更改为Consumer<Param> consumer
,不影响规范的使用 - fixed gitee/I10XWC 允许根据 TableField 信息判断自定义类型
- Merge pull request #1445 from kana112233/3.0
- 支持过滤父类属性功能
- 添加批量异常捕获测试
- 多租户ID 值表达式,支持多个 ID 条件查询
- 扩展新增 json 类型处理器 jackson fastjson 两种实现
- EnumTypeHandler 更名为 MybatisEnumTypeHandler,移除 EnumAnnotationTypeHandler
- 新增自动构建 resultMap 功能,去除转义符
- 注解增加变量控制是否自动生成resultmap
- 修改分页缓存Key值错误
- TableField.el 属性标记过时
- 取消 MybatisMapWrapperFactory 的自动注册
- starter 增加默认xml路径扫描
- 新增 MybatisPlusPropertiesCustomizer 及配置使用
- ConfigurationCustomizer 内部方法入参更新为 MybatisConfiguration
- 原有 fieldStrategy 标记过时,新增 3 种 fieldStrategy 进行区分
- 获取注入方法时传递当前mapperClass
- 增加sqlite代码自动生成测试代码及测试用的数据库文件
- JsqlParserCountOptimize 对 left join 的 sql 优化 count 更精确
- fix(AbstractWrapper.java): 修复 lambda 表达式在 order、groupBy 只有条件一个时引起的类型推断错误
- apply plugin: 'kotlin'
- refactor(order): 修复排序字段优先级问题(#IX1QO)
- 启动就缓存 lambdacache
- Merge pull request #1213 from sandynz/feature/sqlComment 支持SQL注释
- 去除 wrapper 的一些变量,wrapper 内部 string 传递优化
- fix: #1160(github) 分页组件orderBy: 同时存在group by 和order by,且IPage 参数中存在排序属性时,拼接
- Merge pull request #1253 from ShammgodYoung/patch-1 代码生成器输入表名忽略大小写
- 新增渲染对象 MAP 信息预处理注入
- 修改 dts rabbitAdmin bean 判断方式
- Merge pull request #1255 from ShammgodYoung/patch-2 对serialVersionUID属性进行缩进
- JsqlParserCountOptimize 加入 boolean 字段,判断是否优化 join
- Merge pull request #1256 from baomidou/master Master
- freemarker entity 模板缩进调整
- 增加jdbcType,typeHandler属性, 合并el属性
- 新增 996icu license 协议
- 新增 mybatis-plus-dts 分布式事务 rabbit 可靠消息机制
- 新增 DynamicTableNameParser 解析器、支持动态表名
- 优化 getOne 日志打印
- sql 优化跳过存储过程
- 优化分页查询(count为0不继续查询)
- 修复分页一级缓存无法继续翻页问题
- MybatisMapWrapperFactory 自动注入
- 支持纯注解下使用 IPage 的子类作为返回值
- 逻辑删除不再需要 LogicInject
- GlobalConfig 加入 enableSqlRunner 属性控制是否注入 SqlRunner ,默认 false
- SqlParser注解不再需要全局设置参数才会缓存,以及支持注解在 mapper 上
- GlobalConfig 的 sqlParserCache 设置为过时
- mybatis 升级到 3.5.1 , mybatis-spring 升级到 2.0.1 , jsqlparser 降级到 1.2
- ISqlInjector 接口 移除 injectSqlRunner 方法
- SqlFormatter 类设置为过时
- 解决自动注入的 method 的 SqlCommandType 在逻辑删除下混乱问题
- 新增 AlwaysUpdateSomeColumnById 选装件
- SFunction 继承 Function
- DbConfig 的 columnLike 和 dbType 属性设置为过时
- DbConfig 新增 schema 和 columnFormat 属性
- TableField 注解增加 keepGlobalFormat 属性
- TableName 注解增加 schema 和 keepGlobalPrefix 属性
- fixed bug tmp文件格式错乱 github #1048
- 处理表/字段名称抽象 INameConvert 接口策略 github #1038
- DB2支持动态 schema 配置 github #1035
- 把字段缓存的key从className替换成了.class, 如果使用dev-tools会导致:MybatisPlusException: Your property named "xxxx" cannot find the corresponding database column name!(解决方案:去掉dev-tools)
- 升级
mybatis
到3.5.0
版本 - 升级
mybatis-spring
到2.0.0
版本 - 升级
jsqlparser
到1.4
版本 - 新增 p6spy 日志打印支持
- 变更
IService
的getOne(Wrapper<T> queryWrapper)
方法如果获取到多条数据将会抛出TooManyResultsException
异常 - 修复 自定义分页功能不支持注解
@select
问题 - 修复 生成器的配置 kotlin 模式下 swagger 模式无效问题
- 修复 生成器 is 开头字段无法自动注解问题
- 修复 生成器 Serializable Active 模式继承父类包自动导入异常问题
- 修复 生成器 支持公共字段自动读取父类 class 属性问题
- 修复 枚举(注解方式)转换器在存储过程中转换失败
- 修复 beetl 模板逻辑删除注解错误问题
- 修复 通过
mybatis-config.xml
方式构建的Configuration
的mapUnderscoreToCamelCase
默认值非true
的问题 - 修复 sql解析器动态代理引发的bug
- 修复
mapper
使用纯注解下可能触发的重试机制在个别情况下启动报错的问题 - 优化 支持指定
defaultEnumTypeHandler
来进行通用枚举处理 - 优化 从 hibernate copy 最新代码到 SqlFormatter
- 移除
wrapper
的in
以及notIn
方法内部对入参coll
及动态数组
的非empty判断(注意: 如果以前有直接使用以上的方法的入参可能为 empty 的现在会产出如下sql:in ()
或not in ()
导致报错) - 移除
wrapper
的notInOrThrow
和inOrThrow
方法(使用新版的in
以及notIn
效果一样,异常则为sql异常) - 移除
IService
的query
链式调用的delete
操作 - 移除 xml 热加载相关配置项,只保留
MybatisMapperRefresh
该类并打上过时标志 - 日常优化
- 修复 lambdaWrapper 的获取不到主键缓存的问题
- 优化
IService
新增的update
链式调用支持remove
操作 - 过时
IService
新增的query
链式调用的delete
打上过时标识 - 日常优化
- 优化 generator 的 postgresSql 数据库支持生成 java8 时间类型
- 优化 generator 的 sqlServer 数据库支持生成 java8 时间类型
- 优化 LambdaWrapper 反射获取字段信息支持首字母大写的字段
- 优化 仅 LambdaWrapper 的 select 优化(支持字段对不上数据库时自动 as)
- 优化 重复扫描
BaseMapper
子类时,TableInfo
缓存的Configuration
只保留最后一个 - 优化
MergeSegments
获取getSqlSegment
方式 - 优化 SQL 自动注入器的初始化 modelClass 过程,提高初始化速度
- 优化
BaseMapper
的update
方法的第一个入参支持为null
- 新增
IService
增加4个链式调用方法 - 新增 代码生成器增加
beetl
模板 - 新增
IdWorker
增加毫秒时间 ID 可用于订单 ID - 新增 wrapper 新增
inOrThrow
方法,入参为 empty 则抛出MybatisPlusExcuption
异常 - 新增
MetaObjectHandler
新提供几个能根据注解才插入值的default
方法 - 新增 kotlin 下 lambda 的支持,
KtQueryWrapper
和KtUpdateWrapper
类 - 新增 简化MP自定义SQL使用方法,现在可以使用
自定义sql
+ ${ew.customSqlSegment} 方式 - 新增 提供新的
InsertBatchSomeColumn
选装件 - 修复 Page
的
setTotal(Long total)->
setTotal(long total)` - 修复
Page
的setSearchCount
为public
- 修复
TenantSqlParser
如果 where 条件的开头是一个orExpression
,直接在左边用and拼接租户信息会造成逻辑不符合预期的问题 - 修复 wrapper 的
lambda
方法会向下传递 sqlSelect - 修复
ServiceImpl
个别 batch 操作flushStatements
问题 - 修复 selectObjs 泛型错误问题
- 移除
InsertBatchAllColumn
选装件 - 移除
ServiceImpl
的 batch 操作之外的事务注解 - 移除
Model
的事务注解 - 移除
AbstractSqlInjector
的isInjectSqlRunner
方法(SqlRunner初始化较早,目前isInjectSqlRunner无法控制) - 移除
MybatisSessionFactoryBuilder
- 移除 对
mybatis-plus-generator
包的依赖,自己按需引入 - 还原 xml 热加载,打上过时标识
- 升级 jsqlparser 依赖到 1.3
- 日常优化
- 修复entity中2个以上条件并且拼接ODER BY 或 GROUP BY 产生的 WHERE X1 =? AND X2
- refactor(SerializedLambda.java):重构方法增加反序列化安全性,优化命名
- 基础Mapper优化支持自定义父类Mapper构造自己需要的注入方法
- 使用代替
- 部分优化: 直到抛出异常时才进行字符串 format
- 优化 IdWorker 生成UUID使用并发性能
- feat: 动态分页模型、优化分页方言重新修正db2分页语句
- Assert 支持 i18n 多语言错误提示
- 支持 total 控制是否 count sql 新增 isSearchCount 方法
- feat: move spring dependency from core module to extension
- fix: Junit.assertTrue
- 强制使用自定义ParameterHandler,去除byId类型限制.
- 新增选装件的 InsertBatch 通用方法,以及相应测试,以及代码和性能的优化
- IPage 新增功能,泛型转换
- 自动填充判断填充值是否为空,为空时跳过填充逻辑
- batchsize 阈值设 30 修改为 1000 提升效率
- 修复在极端情况下saveOrUpdate执行错误
- 移除 MybatisSqlSessionTemplate
- 移除 xml 热加载
- 其他优化
- 移除 ApiAssert 改为 Assert
- 移除 ApiResult 改为 R
- SQL 注入器优化
- 移除 excludeColumns 方法
- 修复 last 方法的 condition 入参不生效的问题
- 修复去除1=1 BUG
- 移除对 spring-devtools 的支持
- 修复实体属性都为null时Sql拼接出错问题
- 缓存Class反射信息,提升效率
- 继承Model类的实体中,现在无需重写pkVal()方法
- 解决在设置了config-location的情况下报mpe的bug,以及优化初始化逻辑
- 修复存在 mapper.xml 情况下逻辑删除失效
- 调整 关于ServiceImpl中的事务问题 gitee issue/IN8T8
- 修复 DB2分页方言 github issues/526
- 修正全局配置 FieldStrategy 为非默认值
- 修正批量事务异常问题
- Api 层 R 类自动处理逻辑失败
- 修改h2脚本初始化加载,去除测试用例注入.
- 新增注释其它
- 新增筛选查询字段方法
- fixed orderBy多入参的bug
- 新增 LogicDeleteByIdWithFill 组件
- fixed github issues/476 issues/473
- fixed github issues/360 gitee issues/IMIHN IM6GM
- 改进 allEq入参的value改用泛型
- fixed saveOrUpdateBatch使用BatchExecutor
- fixed 修正getOne获取多条数据为抛出异常
- 修正service 的getOne 方法
- 修正service 的个别方法为default方法
- 修复了page在set了desc下,sql有bug的问题
- 去除不再需要的方法
- 解决 generator 的 optional 的俩 jar 问题
- 重载 select(Predicate predicate)
- 其他优化
- 新增 Wrapper 条件辅助类
- 新增 banner 属性控制是否打印
- 修复 gitee #IMMF4:批量插入(AR)事务无效
- fix: entity 无主键,生成 ew 的 where 条件的 bug
- 处理SqlRunner的sqlSession获取与释放
- 去除全局缓存sqlSession,增加Model,通用service层sqlSession释放
- ext: 抽象原生枚举处理类注册,方便扩展
- 优化扩展性其他
- 修复代码生成器设置表前缀异常
- 新增 EnumValue 注解方式扫描通用枚举处理
- 修复逻辑删除混用失败
- DB2 方言改进何鹏举优化
- 新增测试用例及其他
- 乐观锁 update(et,ew)方法 et带上 version 注解字段回写
- 优化改进优化代码生成器
- 包扫描为空时不抛出异常(枚举,别名)
- 去除 SqlSession
- 修改 issue 模板,完善注释
- 优化初始化过程,添加逻辑删除注解次数检测
- SQL检查允许跳过检查
- 支持达梦数据库
- 修改 code 为数值型严谨限制简化 api 层命名及初始值规则
- 初始化 SQL 解析移至 SqlInjector
- 其他代码优化
- 支持 TableField select 属性 false 排除默认注入大字段查询
- 解决 page 反序列化 pages 属性报错
- 合并2.x dataSource被代理处理
- 去除DbConfig.columnUnderline属性
- 过滤掉selectObjs查询结果集为空的情况
- baseMapper 的 insert 和 update 返回值不再使用包装类
- fixed Gitee issues/IM3NW
- 优化代码完善注释等
- 生成器加回 MODULE_NAME 开放配置 config
- 修复setting - defaultEnumTypeHandler属性配置无效
- 兼容 Spring boot 1.x 启动.
- 日常优化 , 测试用例 , 优化抛出异常的过程
- 新增 Gitee Github issue,pull_request模板
- 移除数据库关键字转义, 只支持注解模式转义
- 优化掉抛异常为使用 assert 或者 exceptionUtils
- 设置下划线转驼峰到 configuration 优化 ColumnUnderline
- 解决 page 序列化 asc desc 多态序列化异常
- 默认的 dbType 改为 other, 如果用户没有配置才会自动获取 dbType
- 优化,ColumnUnderline与MapUnderscoreToCamelCase意义相同
- fixed ILY8C 生成器指定 IdType 场景导入包
- 补充注释新增大量测试用例
- 优化工具类部分代码,并修复一个在多线程环境下可能会引发死锁的BUG
- 新增断言类,顺便修改几处地方的判断抛异常为使用断言
- 去掉多余的 "implements Serializable"
- 魔法值都改为全局常量模式
- 咩咩说了 MP 3.0 分页已经飘飘欲仙了,不在需要迁就使用 PageHelper 模式
- issue #384 QueryWrapper 支持排除指定字段模式
- 全新 banner,全新感觉
- 再优化一下抛异常的过程
- 修改 class 实例化对象的方式,现在可以实例化私有 class
- 支持无配置可启动使用 Gitee issues/ILJQA
- 释放sqlSession,待优化 ActiveRecord单元测试
- 解决只调用 last 产生的 sql 会出的问题
- 修复Lambda首位属性为基类属性时错误.
- 增加泛型限制,格式化下代码.
- 优化一下 AbstractWrapper 使用的 ISqlSegment
- 其他
- 优化 page 当 size 小于 0 自动调整为 list 模式
- 新增 攻击 SQL 阻断解析器
- 优化解析核心方法名,新增 querywrapper lambda 转换参数测试
- 调整通用 service 层方法命名为阿里规范 ( 小白鼠,对不起,请唾弃我们吧!然后修改下您的项目。)
- 代码生成器允许正则表达式匹配表名
- 乐观锁 回写更新后的version到实体
- Github #385:查询动态表名能利用Wrapper
- 修复 Gitee issues/ILEYD
- Page 的序列化接口挪到 IPage 接口
- 解决了 gamma 不能自动赋值 ID
- 代码改个常量引用优化
- IPage 新增 listMode 集合模式
- fixd gitee issues/IL7W4
- fixed gitee issues/IL7W4
- 优化生成器包导入
- 解决 Page ascs,descs 异常
- 逻辑删除无法 set where entity 一个参数并存逻辑
- 合并 PR 修改typeAliasesPackage扫描多维度
- 完善 3.0 测试用例
- 代码性能优化及其他
- 新增字段 LIKE 查询注入全局配置,默认 true 开启
- 修改 dbtype 的 oracle db2 修改 CONCAT 方式
- 修正无论 update 的入参 updateWrapper 如何变化,逻辑删除下依然存在限制条件
- 注释加上告警,完善注释
- 修复 github issues/377 378 389
- 解决逻辑删除同时存在非逻辑删除逻辑
- 逻辑删除支持 delete set 其他字段,update 排除逻辑删除字段
- 支持 typeAliasesPackage 多项每项都有通配符 com.a.b..po, com.c..po
- 修复 gitee issues/IKJ48 IL0B2
- 其他完善
- 升级 JDK 8 + 优化性能 Wrapper 支持 lambda 语法
- 模块化 MP 合理的分配各个包结构
- 重构注入方法,支持任意方法精简注入模式
- 全局配置下划线转换消灭注入 AS 语句
- 改造 Wrapper 更改为 QueryWrapper UpdateWrapper
- 重构 分页插件 消灭固定分页模型,支持 Mapper 直接返回 IPage 接口
- 新增 Rest Api 通过 Controller 层
- 实体 String 类型字段默认使用 LIKE 查询 SelectOne 默认 LIMIT 1
- 辅助支持 selectMaps 新增 bean map 互转工具类
- 增加 db2 支持 starter 改为 Spring boot 2+ 支持
- 重构生成器提供自定义 DB 多种模板引擎支持
- 相关 BUG 修复
- page 分页新增控制是否优化 Count Sql 设置
// 不进行 count sql 优化
page.setOptimizeCountSql(false);
- 注入定义填充,支持sql注入器,主键生成器.
- fixed github issues/231
- fixed github issues/234
- 修改逻辑删除 selectByIds coll 问题
- fixed gitee issues/IHF7N
- fixed gitee issues/IHH83
- 兼容配置方式,优先使用自定义注入.
- 其他优化
- 调整 Gradle 依赖模式
- IdType 可选 ID_WORKER_STR
字符串类型
IdWorker.getIdStr() 字符串类型 - TableField 注解新增属性
update
预处理 set 字段自定义注入 fixed gitee IHART
例如:@TableField(.. , update="%s+1") 其中 %s 会填充为字段
输出 SQL 为:update 表 set 字段=字段+1 where ...
例如:@TableField(.. , update="now()") 使用数据库时间
输出 SQL 为:update 表 set 字段=now() where ...
- TableField 注解新增属性
condition
预处理 WHERE 实体条件自定义运算规则
@TableField(condition = SqlCondition.LIKE)
private String name;
输出 SQL 为:select 表 where name LIKE CONCAT('%',值,'%')
- 添加 spring-boot-starter 模块内置
jdbc mp 包不需要单独引入
更舒服的使用 boot - 添加对 SQL Server 视图生成的支持
- 允许字段策略独立设置,默认为 naming 策略
strategy.setNaming(NamingStrategy.underline_to_camel);// 表名生成策略
strategy.setColumnNaming(NamingStrategy.underline_to_camel);// 允许字段策略独立设置,默认为 naming 策略
- 代码生成器抽象 AbstractTemplateEngine 模板引擎抽象类,可自定义模板引擎,新增内置 freemarker 可选
// 选择 freemarker 引擎
mpg.setTemplateEngine(new FreemarkerTemplateEngine());
- 相关 SQL 解析如多租户可通过
@SqlParser(filter=true)
排除 SQL 解析
# 开启 SQL 解析缓存注解生效
mybatis-plus:
global-config:
sql-parser-cache: true
- 解决xml加载顺序问题,可随意引入其他 xml sql 片段
- 修复 author 带123的bug
- fix #IGQGE:Wrapper为空,但是page.getCondition()不为空的情况,Condition无法传递问题
- fix #IH6ED:Pagination dubbo 排序等属性序列化不支持
- 判断Wrapper是否为空,使用==,避免被equals方法重载的影响
- 避免注入自定义基类
- 剥离 sql 单独提出至 SqlUtils
- 统一缩进编码风格
- 优化生成代码执行性能 github issues/219
- 优化 sql 解析过程
- fixed gitee issues/IHCQB
- springboot-configuration-processor 修改 compileOnly为optional
- 其他
- 修复代码生成器>字段前缀导致的bug
- 使用类全名替代手写的全名
- build修改
- 脚本警告,忽略目录
- 其他优化
- 返回Map自动下划线转驼峰
- kotlin entity 静态常量支持
- 优化 pagination 构造模式
- Merge pull request #201
- fix: selectByMap @alexqdjay
- 增加sqlRuner测试用例,修复selectObjs只获取一个字段的bug
- 新增 BlobTypeHandler
- 去掉参数map的初始大小配置
- 增加.editorconfig,模板空格问题修复.
- Hikaricp连接池无法打印sql
- 全局中去掉了路径,mapperLocations不可缺少了.
- k 神 全部覆盖测试用例
- 枚举处理:基本类型,Number类型,String类型
- IGDRW:源码注释错误,容易给人误导 注释错误问题
- 炮灰 PR !42:添加分页构造方法重载 添加分页构造方法重载
- 代码生成 > oracle > 解决超出最大游标的问题
- fixed gitee IGNL9
- k 神 一大波 testcase 来袭
- 使用transient关键字去除Page中部分字段参与序列化
- 去除无效日志
- fix #IGI3H:selectBatchIds 参数改为Collection类型
- bugfix for logic delete sql injector
- 添加多个排序字段支持
- fixed github #185:2.0.2版本 自增主键 批量插入问题 pr
- 其他优化`
- 模块拆分为 support core generate 代码生成分离可选择依赖
- 解决 gitee issue IFX30 拆分 mybatis-plus-support 包支持
- 解决 gitee issue IGAPX 通用枚举 bigdecimal 类型映射
- druid补充,填充字段修改
- 修复 kotlin 代码生成部分逻辑 Bug
- 合并 gitee pr 40 updateAllColumn****等方法排除fill = FieldFill.INSERT注释的字段 感谢 Elsif
- 构造模式设置 kotlin 修改
- Sql 工具类反射实例优化
- 其他优化
- 通用枚举 spring boot 兼容调整
- PostgreSQL 支持关键词非关键词转换问题
- Cat73 PR 稍微调整下自动生成的代码
- 支持 kotlin 代码生成
- bugfix for metaObj handler set val which not included in ...
- alibaba 规范调整
- 其他
- 新增通用枚举处理器,参考 spring boot demno
- 优化 SQL 解析器
- 新增 schema 租户解析器待完善
- 其他优化
- 修复代码生成器 Bug
- fixed gitee issues/IF2DY
- 修改 page 可链式操作
- 去掉转义 oracle
- fixed github issues/119
- fixed gitee issues/IF2OI
- 修改分页超过总记录数自动设置第一页 bug @wujing 感谢 pr
- fixed IEID6
- 升级 mybatis 3.4.5
- 升级生成器模板引擎 veloctiy 2.0
- 升级 jsqlparser 1.1
- 新增 SQL 解析链可动态扩展自定义 SQL 解析
- 新增 多租户 SQL 解析逻辑,具体查看 spring boot 演示 demo
- jasonlong10 PR 性能分析拦截器 支持OraclePreparedStatementWrapper的情况打印 SQL
- fixed github issues/145
- fixed gitee issue/IF1OF
- add sqlSelect("distinct test_type") test case
- 添加填充生成器遗漏 TableField 导入类
- fixed github issues/MYSQL表名含有保留字代码生成时报错 #124:字段全为 大写 下划线命名支持
- fixed github issues/134
- PostgreSQL 代码生成支持指定 schema 表字段按照默认排序
- 其他优化调整
####主体功能
- 批量sqlSession没有关闭问题修复
- 处理sql格式化报错问题,添加填充信息
- #91:关于insertBatch在大数据量的时候优化 github
- 新增 uuid 主键测试用例
- 修复BUG自动填充会覆盖之前的值
- 升级pom依赖,spring-test作用域test
- 更改sqlServer驱动,去掉乐观锁不需要的string类型测试
- #86:关于plus的底层映射设计问题 github issue
- SqlHelper处理Wrapper为空,但是page.getCondition()不为空的情况
- Merge pull request !33:生成实体增加字段排序 from 老千/master
- 解决使用代理对象导致无法获取实例缓存信息
- 解决布尔类型is开头生成sql错误问题
- DBType设置错误
- fix #351:DB2Dialect返回NULL
- fix #356:自动代码生成的Boolean类型的get方法不对
- fix #353:代码生成@TableLogic问题
- 新增 PostgreSqlInjector 自动注入器,处理字段大小写敏感,自动双引号转义。
- 仓库地址与用户信息使用自定义传入.
- fix #357:代码生成@TableLogic引入包Bug
- Sequence 新增 mac 判断,分页 pageHelper 模式新增 freeTotal() 方法
- #95:分页插件俩个建议 Github, selectItems contains #{} ${},
- 添加 Wrapper#setSqlSelect(String... columns) 方法,方便通过自动生成的实体...
- fixed github 116 issue
- fixed osgit IE436 IDVPZ IDTZH
####代码生成
- 修改实体生成模板
- 修复自动填充代码生成错误
- 新增 postgresql schemaname 生成器支持
- 调整序列化导入问题
- 其他
####主体功能
- 修正之前sqlserver自动获取类型错误问题
- 修复用户无法自定义分页数据库方言问题
####代码生成
- 完善了自动填充代码生成
- 修复postgresql生成重复字段问题
####上个版本(2.0.9)升级导致的问题
- 修复实体主键不在第一位无法读取的问题
- 修复在自定义insert操作时报
Insert not found et
异常,见#331 - 修复Sql生成错误问题(普通注入Group,Having,Order)
- 修复逻辑删除生成Sql顺序错误
- 感谢各路小伙伴及时反馈的问题,上个版本给大家带来的问题深感抱歉
###Mybatis-Plus-Boot-Start [1.0.4]
####主体变动
- 去除Mybatis-plus直接依赖
- 去除SpringBoot jdbc-starter直接依赖
###Mybaits-Plus ####主体功能
- 修正乐观锁和逻辑删除冲突问题
- 处理在生成注入SQL时之前没有考虑到存在且打开下划线配置情况
- 修复EntityWrapper继承关系问题
- Wrapper添加条件判断
- 性能分析插件支持记录日志提示
- Wrapper重写了toString方式,解决之前Debug时显示为null给用户造成错觉
- 处理Sequence非毫秒内并发偶数居多问题
- 忽略策略优化处理更改了注解的属性
- 注入Sql的方式优化,去除之前XML注入方式
- 处理逻辑删除出现2个Where的问题
- 添加其他数据库序列的实现方式,并开放出接口给用户自行扩展
- 乐观锁优化调整
- 优化Wrapper中Where AND OR 去除之前基于反射方式实现,提高代码运行效率
- 处理不添加mybatis-config.xml主键无法填充问题
- MybatisPlus添加支持gradle构建方式
- Wrapper 添加
and()
or()
方法 - 优化GlobalConfiguration,抽离出GlobalConfigUtils减少耦合
- 修复Sqlserver2008与SqlServer2005分页问题
- 新增自动识别数据库,减少用户显式配置
- 优化分页插件减少用户显示配置属性
- 自动填充字段问题解决
- 新增PageHelper,获取当前线程来管理分页(之前老用户最好不要使用,改方式只用户适用MybatisPageHelper用户习惯)
- 大幅度的添加测试用例(感谢K神支持)
- 代码的其他优化
- 添加了JSqlparser的依赖以后不用手动去添加该Jar包
####代码生成
- 支持逻辑删除方式生成
- 支持乐观锁方式生成
- 修复生成器不能识别sqlServer的自增主键代码生成器不能识别SqlServer自增主键的问题
- 支持Lombok方式生成
- 支持构建模式方式生成
- 添加Clob和Blob类型转换
- 修复Oracle的Number类型字段转换错误问题
###Mybatis-Plus-Boot-Start [1.0.2] 代号:清风 ####主体功能
- 处理AR模式devtool替换数据源失效问题
- 添加逻辑删除支持
- 添加序列支持
- Wrapper添加设置对象sqlSelect
- 兼容无注解情况
- 乐观锁去除默认short实现,优化绑定注册器在扫描阶段绑定. 测试改为h2环境.
- 优化热加载,去除mapper路径配置.
- 减少刷新Mapper配置
- 修复tableFiled value 为空情况,开启下划线命名
- sequence 升级提示
- 开放表信息、预留子类重写
- 修改Idwork测试
- 支持 devtools
- fixed 259 支持 xml resultMap 公共字段生成
- fixed pulls 28 支持属性重载
- 新增 逻辑删除
- 新增 Oracle Sequence
- 新增 jdk1.8 时间类型
- 完善支持乐观锁
- 完善字段填充器,支持更新填充
- 升级 mybatis 依赖为 3.4.4
- 代码调整优化,支持 wrapper limit 等逻辑
- 修复 Id 策略 auto bug ,生成器 bug 其他
- 修复分页连接池没有关闭的bug
- issues fixed 217
- IMetaObjectHandler当主键类型是AUTO或者INPUT的时候不起效的bug
- 修复 like 占位符问题
- 生成代码的时候如果目录不存在则新建
- 优化Wrapper代码结构
- 优化原有数据库连接获取
- 解决Page初始化问题(之前只能通过构造方法生效,现在可以通过setget也可以生效)
- 支持乐观锁插件
- 改造Wrapper让JDBC底层来处理参数,更好的与PreparedStatement结合
- 修复相关错误日志提示级别
- Wrapper开放isWhere方法,现在可以自定义是否拼接"WHERE"
- JDK版本向下兼容,之前相关代码用到了1.7新特性,当前版本解除
- sqlserver生成bug修复以及代码优化
- 优化MybatisPlus,SqlSession获取
- 解决未配置切点的情况下获取的sqlSession提交不属于当前事务的问题以及多个sqlSession造成的事务问题
- 增强执行sql类,sqlRunner
- Model添加序列化ID,避免以后在修改Model后没有设置序列号ID时序列号ID可以会变动的情况
- 添加重写默认BaseMapper测试用例
- 感谢各路小伙伴提问的好的建议以及贡献代码,就不一一点名了
- 修复全局配置不起作用 2.0.1 逻辑
- 去除byId强制配置类型
- Wrapper Page 等程序优化
- 优化AR模式自动关闭数据库连接(之前需要手动设置事务)
- 优化代码生成器,下划线名称注解不处理驼峰,支持自定义更多的模板例如 jsp html 等
- 新增 service 层测试
- sql日志记录整合至性能分析插件.
- 处理多数据源分页插件支持多重数据库
- 解决EntityWrapper对布尔类型构造sql语句错误
- 全局配置初始化日志提示调整
- Mybatis依赖升级至3.4.2,Mybatis-Spring依赖升级至1.3.1
- Service中补充方法(selectObjs,selectMaps)
- 解决selectCount数据库返回null报错问题
- 支持PostgreSql代码生成
- 拓展支持外部提供转义字符以及关键字列表
- 开放数据库表无主键依然注入MP的CRUD(无主键不能使用MP的xxById方法)
- 解决EntityWrapper拼接SQL时,首次调用OR方法不起作用的问题
- sqlServer代码生成(基于2008版本)
- 解决生成代码时未导入BigDecimal问题.
- 释放自动读取数据库时的数据库连接
- 优化全局校验机制(机制为EMPTY增加忽略Date类型)
- 优化注入,避免扫描到BaseMapper
- 优化注入,去除多余注入方法
- SQLlikeType改名为SqlLike
- 解决热加载关联查询错误问题
- SqlQuery改名为SqlRunner
- 优化完善代码生成器
- 修复代码生成器未导入@tableName
- 全局配置需要手动添加MP的默认注入类,更改为自动注入简化配置
- Wrapper增加ne方法
- 修复Mybatis动态参数无法生成totalCount问题
- 代码结构优化,生成器模板优化
- 解决issus[138,140,142,148,151,152,153,156,157],具体请查看里程碑mybatis-plus 2.0.1 计划中所有issus
- 支持全局大写命名策略
- 自动分页Count语句优化
- 优化现有全局配置策略
- 优化全局验证策略
- 优化代码生成器(之前硬编码,现使用模板形式)
- 优化注入通用方法ByMap逻辑
- 添加自动选择数据库类型
- 改善SqlExplainInterceptor(自行判断MySQL版本不支持该拦截器则直接放行(版本过低小于5.6.3))
- 修复部分特殊字符字符多次转义的问题
- 优化现有EntityWrapper添加Wrapper父类以及Condition链式查询
- Wrapper类使LIKE方法兼容多种数据库
- 优化日志使用原生Mybatis自带的日志输出提示信息
- 修复使用缓存导致使用分页无法计算Count值
- 修复PerformanceInterceptor替换
?
导致打印SQL不准确问题,并添加格式化SQL选项 - 添加多种数据库支持,请查看DBType
- 添加字符串类型字段非空校验策略(字符串类型自动判断非空以及非空字符串)
- Wrapper添加类似QBC查询(eq、gt、lt等等)
- 支持AR模式(需继承Model)
- 合并所有Selective通用方法(例如:去除之前的insert方法并把之前的insetSelective改名为insert)
- 解决sql剥离器会去除
--
的情况 - 支持MySQL关键词,自动转义
- 精简底层Service、Mapper继承结构
- 不喜欢在XML中写SQL的福音,新增执行SQL方式,具体请查看SqlQuery
- 优化代码结构
- 解决issus[95,96,98,100,103,104,108,114,119,121,123,124,125,126,127,128,131,133,134,135],具体请查看里程碑mybatis-plus 2.0 计划中所有issus
- ServiceImpl去除@Transactional注解、去除Slf4j依赖
- 解决使用EntityWrapper查询时,参数为特殊字符时,存在sql注入问题
- 调整Mybatis驼峰配置顺序 MybatisPlus > Mybatis
- 优化分页插件并修复分页溢出设置不起作用问题
- 去除DBKeywordsProcessor,添加MySQL自动转义关键词
- 代码生成器新增支持TEXT、TIME、TIMESTAMP类型生成
- 新增批量插入方法
- 代码生成器新增Controller层代码生成
- 调整EntityWrapper类部分List入参为Collection
- 代码生成器优化支持 resultMap
- insertOrUpdate增加主键空字符串判断
- 支持Mybatis原生驼峰配置 mapUnderscoreToCamelCase 开关设置
- 支持 TableField FieldStrategy 注解全局配置
- SelectOne、SelectCount方法支持EntityWrapper方式
- oracle 代码生成器支持 Integer Long Dobule 类型区分
- 修复INPUT主键策略InsertOrUpdate方法Bug
- EntityWrapper IN 添加可变数组支持
- 基础Mapper、Servcie通用方法PK参数类型更改至Serializable
- 当selectOne结果集不唯一时,添加警告提示(需开启日志warn模式)
- baseService添加logger,子类直接调用logger不用重新定义(需slf4j依赖)
- 主键注解 I 改为 PK 方便理解,去掉 mapper 注解
- 性能分析插件,特殊处理 $ 符内容
- 添加自动提交事务说明,新增事务测试
- 支持 resultMap 实体结果集映射
- 增加#TableField(el = "")表达式,当该Field为对象时, 可使用#{对象.属性}来映射到数据表、及测试
- 新增 typeHanler 级联查询支持
- 新增验证字段策略枚举类
- 代码生成器支持实体构建者模型设置
- 代码生成器新增实体常量生成支持
- CRUD 新增 insertOrUpdate 方法
- 解决MessageFormat.format格式化数字类型sql错误
- EntityWrapper添加 EXISTS、IN、BETWEEN AND(感谢D.Yang提出)方法支持
- 支持 mysql5.7+ json enum 类型,代码生成
- 支持无XML依然注入CRUD方法
- 修改Mybatis原生配置文件加载顺序
- 新增无 @TableId 注解跳过注入SQL
- 支持非表映射对象插入不执行填充
- xxxByMap 支持 null 查询
- 新增 XML 修改自动热加载功能
- 添加自动处理EntityWrapper方法中的MessageFormat Params类型为字符串的参数
- 新增表公共字段自动填充功能
- entitywrapper所有条件类方法支持传入null参数,该条件不会附件到SQL语句中
- TSQLPlus更名为TSqlPlus与整体命名保持一致。
- 修复mysql关键字bug----将关键字映射转换加上``符号,增加xml文件生成时可自定义文件后缀名
- 关闭资源前增加非空判断,避免错误sql引起的空指针错误,增加选择 current>pages 判断
- TSQL 相关类实现序列化支持 dubbo
- 增加 mybatis 自动热加载插件
- 支持数据库 order key 等关键词转义 curd 操作
- 优化 Sequence 兼容无法获取 mac 情况
- 兼容用户设置 ID 空字符串,自动填充
- 纯大写命名,转为小写属性
- 修改EntityWrapper符合T-SQL语法标准的条件进行方法封装定义
- 升级 1.4.3 测试传递依赖
- 增加自定义 select 结果集,优化 page 分页
- 未考虑 函数,去掉 field 优化
- 新增 delete update 全表操作禁止执行拦截器
- 修复 bug
- 解决插入 map 异常
- 插入 map 不处理,原样返回
- 优化 IdWorker 生成器
- 支持自定义 LanguageDriver
- 支持代码生成自定义类名
- 升级 mybatis 3.4.1 依赖
- 支持全局表字段下划线命名设置
- 增加自定义 注入 sql 方法
- 优化分页总记录数为0不执行列表查询逻辑
- 自动生成 xml 基础字段增加 AS 处理
- 支持字段子查询
- 升级 1.3.5 支持全局表字段下划线命名设置
- 添加发现设置多个主键注解抛出异常
- 添加无主键主键启动异常
- 去掉重置 getDefaultScriptingLanuageInstance
- 修改歧义重载方法
- 处理 SimpleDateFormat 非现场安全问题
- 修改 oracle 分页 bug 修复
- oracle TIMESTAMP 生成支持 bug 修复
- service 暴露 sqlSegment 的方法调用
- 新增 sql 执行性能分析 plugins
- 新增 deleteByMap , selectByMap
- 支持 like 比较等查询 sqlSegment 实现
- 支持 typeAliasesPackage 通配符扫描, 无 count 分页查询
- mybatis mapper 方法调用执行原理测试
- 添加 IOC 演示用例
- 优化 代码生成器 感谢 yanghu pull request
- 调整 sql 加载顺序 xmlSql > curdSql
- 支持 CURD 二级缓存
- 增加缓存测试,及特殊字符测试
- 新增 支持oracle 自动代码生成,测试 功能
- 新增 UUID 策略
- 演示demo 点击 spring-wind
- 新增支持单表 count 查询
- 添加 service 层支持泛型 id 支持,自动生成代码优化
- 升级 mybatis 为 3.4.0 ,mybatis-spring 为 1.3.0
- 新增批量更新,支持 oracle 批量操作
- 去掉,移植至 spring-wind 的文档
- 支持 jdk1.5 修改 param 描述
- 添加数据库类型
- EntityWrapper 新增无 order by 构造方法
- MailHelper 重载 sendMail 方法
- 新增 String 主键ID 支持 CommonMapper
- 原来方法 selectList 分离为 selectList , selectPage 两个方法
- 优化代码生成器,添加文档说明、其他
- 优化生成代码处理大写字段,支持自动生成 entity mapper service 文件
- 优化分页 index 超出逻辑,新增 5 个 CRUD 操作方法
- 开放模板引擎 getHtmltext 方法
- 优化邮件发送配置添加说明文档
- 添加文档说明、其他
- 优化代码 service 层封装,抽离 list 、 page 方法
- 优化分页 count sql 语句
- 改进 mail 工具类
- 完善 framework 对 spring 框架的支持
- 添加文档说明、其他
- 独立支持id泛型的 baseMapper
- 更完善的自动生成工具
- 支持实体封装排序
- 分页插件完善
- 抽离 service 主键泛型支持
- 注解 ID 区分 AUTO 数据库自增,ID_WORKER 自动填充自定义自增ID , INPUT 手动输入 。
- 优化代码及自动生成器功能。
- 其他