公司的有个项目是用mysql的作的,我本身的机子上装的是mysql 5.0 ,个人上司装的是5.1.在用spring 的jdbcTemple的方式进行查询,而后把查询出来的list<map>直接放在json的格式中,但一直没法解析。但我上司那边就能够解析,郁闷了,找了老半天都找不出缘由,各个问题都排除了,最终无奈改了下mysql的版本,用上mysql 5.1,神奇的事情发生了,能够解析了。mysql
我特地去学习了下各个版本的区别。linux
-----下面的抄别人的,算法
- MySQL 4.1/5.0/5.1/5.5/5.6各版本的主要区别
- 一、4.1 增长了子查询的支持,字符集增长UTF-8,GROUP BY语句增长了ROLLUP,mysql.user表采用了更好的加密算法。
- 二、5.0 增长了Stored procedures、Views、Cursors、Triggers、XA transactions的支持,增长了INFORATION_SCHEMA系统数据库。
- 三、5.1 增长了Event scheduler,Partitioning,Pluggable storage engine API ,Row-based replication、Global级别动态修改general query log和slow query log的支持。
- 四、5.5的新特征
- 1)默认存储引擎更改成InnoDB
- 2)提升性能和可扩展性
- a. 提升了默认线程并发数(innodb_thread_concurrency)
- b. 后台输入/输出线程控制(innodb_read_io_threads、innodb_write_io_threads)
- c. 主线程输入/输出速率控制(innodb_io_capacity)
- d. 操做系统内存分配程序使用控制(innodb_use_sys_malloc)
- e. 适应性散列索引(Hash Index)控制,用户能够关闭适应性散列功能。
- f. 插入缓冲(Insert Buffering)控制,用户能够关闭innodb的插入缓冲功能。
- g. 经过快速加锁算法提升可扩展性,innodb不在使用代理(posix)线程,而是使用原生的独立操做来完成互斥和读写锁定。
- h. 恢复组提交(Restored Group Commit)
- i. 提升恢复性能
- j. 多缓冲池实例
- k. 多个回滚段(Multiple Rollback Segments),以前的innodb版本最大能处理1023个并发处理操做,如今mysql5.5能够处理高达128K的并发事物,
- l. Linux系统固有的异步输入/输出,mysql5.5数据库系统也提升了linux系统的输入输出请求的并发数。
- m. 扩展变化缓冲:添加了删除缓冲和清除缓冲
- n. 改善了日志系统互斥和单独刷新(Flush)列表互斥
- o. 改善清除程序进度,在mysql5.5中清楚操做线程是独立的线程,并支持并发,能够使用innodb_purge_treads配置。
- p. 改善事务处理中的元数据锁定。例如,事物中一个语句须要锁一个表,会在事物结束时释放这个表,而不是像之前在语句结束时释放表。
- 3)提升实用性
- a. 半同步复制(Semi-synchronous Replication)
- b. 复制Heartbeat
- c. 中继日志自动恢复(Automatic Relay Log Recovery)
- d. 根据服务器过滤项复制(Replication Per Server Filtering)
- e. 从服务器复制支持的数据类型转换(Replication Slave Side Data Type Conversions)
- 4)提升易管理性和效率
- a. 创建快速索引(Faster Index Creation)
- b. 高效的数据压缩(Efficient Data Compression)
- c. 为大物件和可变长度列提供高效存储
- d. 增长了INFORMATION_SCHEMA表,新的表提供了与InnoDB压缩和事务处理锁定有关的具体信息。
- 5)提升可用性
- a. 针对SIGNAL/RESIGNAL的新SQL语法
- b. 新的表/索引分区选项。MySQL5.5将表和索引RANG和LIST分区范围扩展到了非整数列和日期,并增长了在多个列上分区的能力。
- 6)改善检测和诊断
- Mysql5.5引入了一种新的性能架构(performancn_shema,P_S),用于监控mysql监控服务器运行时的性能。
五、5.6的新特征 1)InnoDB如今能够限制大量表打开的时候内存占用过多的问题(好比这里提到的)(第三方已有补丁) 2)InnoDB性能增强。如分拆kernel mutex;flush操做从主线程分离;多个perge线程;大内存优化等 3)InnoDB死锁信息能够记录到 error 日志,方便分析 4)MySQL5.6支持延时复制,可让slave跟master之间控制一个时间间隔,方便特殊状况下的数据恢复。 5)表分区功能加强 6)MySQL行级复制功能增强,能够下降磁盘、内存、网络等资源开销(只记录能肯定行记录的字段便可) 7)Binlog实现 crash-safe 8)复制事件采用crc32校验,加强master/slave 复制数据一致性 9)新增 log_bin_basename (之前variables里面没有binlog位置信息,对数据库的监管很不方便)