Skip to content

Latest commit

 

History

History
204 lines (130 loc) · 11 KB

RELEASE-NOTES.md

File metadata and controls

204 lines (130 loc) · 11 KB

1.5.0

里程碑

  1. 全新的SQL解析模块,去掉对Druid的依赖。仅解析分片上下文,对于SQL采用"半理解"理念,进一步提升性能和兼容性,并降低代码复杂度
  2. 全新的SQL改写模块,增加优化性改写模块
  3. 全新的SQL归并模块,重构为流式、内存以及装饰者3种归并引擎

新功能

  1. 增加对Oracle,SQLServer和PostgreSQL的支持
  2. 非功能型子查询支持

功能提升

  1. ISSUE #256 可配置显示分片执行SQL日志
  2. ISSUE #291 用流式方式处理仅包含GroupBy的SQL

功能调整

  1. 简化分布式自增序列。将每个表支持多自增序列简化为单表仅支持单一的分布式自增序列,并不再支持通过环境变量设置workerID。
  2. 去掉对OR的支持

缺陷修正

  1. ISSUE #239 LIMIT路由至多查询结果集,若只有一个不为空的结果集,分页结果不正确
  2. ISSUE #263 分片列和逻辑表配置可忽略大小写
  3. ISSUE #292 内存方式处理GROUP BY语句如有分页信息则需改写
  4. ISSUE #295 LIMIT 0的情况并未按照分页限制条件过滤结果集

1.4.2

功能提升

  1. ISSUE #219 线程性能优化
  2. ISSUE #215 流式排序的聚集结果集 StreamingOrderByReducerResultSet性能优化
  3. ISSUE #161 结果集归并的时候可以采用堆排序来提升性能

缺陷修正

  1. ISSUE #212 对去缺少数据源规则给出更有意义的提示
  2. ISSUE #214 where中 table_name.column_name in (?,?)无法解析表达式
  3. ISSUE #180 批量执行Update返回值不准确
  4. ISSUE #225 自动生成Id最后一位不归零

1.4.1

功能提升

  1. ISSUE #191 根据主机的IP生成workerId的KeyGenerator实现
  2. ISSUE #192 根据HOSTNAME的数字尾缀获取workerId的KeyGenerator
  3. ISSUE #210 路由到单库单表移除补充的SQL语句片段

缺陷修正

  1. ISSUE #194 jdbc接口中资源释放错误
  2. ISSUE #199 分表且复用PreparedStatement对象造成数据路由错误
  3. ISSUE #201 批量操作执行前事件发送缺失
  4. ISSUE #203 合并batch操作发送的事件
  5. ISSUE #209 limit并行异常

1.4.0

功能提升

自动生成键实现,包含

  1. ISSUE #162 分布式主键算法实现
  2. ISSUE #163 获取自增序列jdbc接口实现
  3. ISSUE #171 sharding-jdbc-core配合自动生成序列改造
  4. ISSUE #172 YAML与Spring的配置方式增加对于自增序列的支持

缺陷修正

  1. ISSUE #176 AbstractMemoryResultSet对SQL的wasNull实现有问题

1.3.3

功能提升

  1. ISSUE #59 PreparedStatement设置参数时可以根据参数类型调用正确的底层set方法

缺陷修正

  1. ISSUE #149 INSERT IGNORE INTO时如果数据重了忽略时返回的成-1了,应该返回0
  2. ISSUE #118 同一个线程内先执行DQL后执行DML,DML操作在从库上执行
  3. ISSUE #122 bed的fail重试问题
  4. ISSUE #152 可能同一个connection多线程导致问题
  5. ISSUE #150 与最新SQLServer jdbc驱动兼容问题
  6. ISSUE #166 druid数据源stat过滤器多线程报错

1.3.2

功能提升

  1. ISSUE #79 关于MySQL 分页limit

缺陷修正

  1. ISSUE #36 ShardingPreparedStatement无法反复设置参数
  2. ISSUE #114 ShardingPreparedStatement执行批处理任务时,反复解析sql导致oom
  3. ISSUE #33 Limit支持问题
  4. ISSUE #124 com.dangdang.ddframe.rdb.sharding.jdbc.adapter.AbstractStatementAdapter.getUpdateCount返回值不符合JDBC规范
  5. ISSUE #141 多线程执行器参数设置失效

1.3.1

功能提升

  1. ISSUE #91 开放对Statement.getGeneratedKeys的支持,可返回原生的数据库自增主键
  2. ISSUE #92 查询类DQL语句事件发送

缺陷修正

  1. ISSUE #89 读写分离和分片的hint一起使用导致冲突
  2. ISSUE #95 同一线程内写入操作后的读操作均从主库读取改为同一线程且同一连接内

1.3.0

新功能

  1. ISSUE #85 读写分离

功能提升

  1. ISSUE #82 TableRule可传入dataSourceName属性,用于指定该TableRule对应的数据源
  2. ISSUE #88 放开对其他数据库的限制,可支持标准SQL, 对个性化分页等语句不支持

缺陷修正

  1. ISSUE #81 关联表查询使用or查询条件解析结果异常

1.2.1

结构调整

  1. ISSUE #60 API调整,抽离ShardingDataSource,使用工厂代替
  2. ISSUE #76 ShardingRule和TableRule调整为Builder模式
  3. ISSUE #77 ShardingRule和TableRule调整为Builder模式

功能提升

  1. ISSUE #61 在ShardingValue类中加入逻辑表名
  2. ISSUE #66 在JDBC层的Statement增加对get/set MaxFieldSize,MaxRows和QueryTimeout的支持
  3. ISSUE #72 对于select union all形式的批量插入支持
  4. ISSUE #78 简化只分库配置,无需配置逻辑表和真实表对应关系
  5. ISSUE #80 简化包含不分片库表的配置,可指定默认数据源,不分片无需配置TableRule

缺陷修正

  1. ISSUE #63 ORDER BY与GROUP BY衍生列未添加表名或表别名
  2. ISSUE #65 解析条件上下文性能提升
  3. ISSUE #67 分片路由到多表时柔性事务日志无法删除
  4. ISSUE #71 路由单分片LIMIT的OFFSET计算错误
  5. ISSUE #75 MemoryTransactionLogStorage重试次数更新并发问题

1.2.0

新功能

  1. ISSUE #53 动态表配置
  2. ISSUE #58 柔性事务:最大努力送达型初始版本

结构调整

  1. ISSUE #49 调整属性配置
  2. ISSUE #51 重构Hint接口

缺陷修正

  1. ISSUE #43 yaml文件中包含中文,且操作系统模式不是utf-8编码导致的yaml不能解析
  2. ISSUE #48 yaml文件读取后未关闭
  3. ISSUE #57 SQL解析子查询改进

1.1.0

新功能

  1. ISSUE #40 支持YAML文件配置
  2. ISSUE #41 支持Spring命名空间配置
  3. ISSUE #42 支持inline表达式配置

缺陷修正

  1. ISSUE #25 OR表达式下会出现重复结果问题

1.0.1

功能提升

  1. ISSUE #39 增加使用暗示(Hint)方式注册分片键值的方式进行SQL路由的功能

缺陷修正

  1. ISSUE #11 count函数在某些情况下返回不正确
  2. ISSUE #13 Insert 语句 没有写列名 进行了全路由
  3. ISSUE #16 改造多线程执行模型
  4. ISSUE #18 查询Count时,使用getObject()取数会报异常
  5. ISSUE #19 sum和avg函数,不加别名不执行merger,加了空指针异常
  6. ISSUE #38 JPA与Sharding-JDBC的兼容问题。JPA会自动增加SELECT的列别名,导致ORDER BY只能通过别名,而非列名称获取ResultSet的数据

1.0.0

  1. 初始版本