MySql5.7新特性

Mysql 5.7新特性:
    3倍更快的性能
    InnoDB 相关改进
     新的优化器
    多源复制
   GIS 相关改进
    原生 JSON支持

一:mysql在服务方面的新特性:
1.初始化方式改变(安全性)
初始化完成后为root@localhost用户提供一个默认密码,5.7版本之前密码是空的,还是为安全考虑。
第一次进入mysql命令行,强制修改密码,否则你无法进行任何操作:

mysql> alter user root@localhost identified by "root";
1.1MySQL 5.7版本提供了更为简单SSL安全访问配置,并且默认连接就采用SSL的加密方式
1.2可以为用户设置密码过期策略,一定时间以后,强制用户修改密码
2.去掉了test库
3.新版本中支持为表添加计算列,只需要在建表/修改表时添加列的as参数就可以了

mysql> create table t2(id int auto_increment not null,c1 int ,c2 int ,c3 int as(c1+c2),primary key(id));
通过这样的命令,c3的值会在c1和c2新增之后 自动计算
mysql> insert into t2(c1,c2) values(2,3);
Query OK, 1 row affected (0.01 sec)

 

mysql> select * from t2;
+----+------+------+------+
| id | c1   | c2   | c3   |
+----+------+------+------+
|  1 |    2 |    3 |    5 |
+----+------+------+------+

4.引入json数据类型及相关函数
之前我们只能在varchar和text等字符串列中存储json类型的字符串,然后通过程序解析使用json
新版本中增加了json列类型以及json类型的函数,如:json_type()
json_object,json_merge()
新增json列实例:
| json_test | CREATE TABLE `json_test` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `jos` json NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1 |
引入json之后的优势是:
1.可以混合存储结构化数据和非结构化数据,同时拥有关系型数据库和非关系型数据库的优点
2.能够提供完整的事务支持

二、MySql5.7在复制中的新特性
5.7之前是一主多从一般都是这样的架构形式

MySql5.7新特性_第1张图片

之后实现了多主一从的方式,这种方式也有很多用处,比如我们利用从库备份,以前都是一主一从,现在可以将多主复制到一从上,这样省了很多机器,节约了成本。

MySql5.7新特性_第2张图片

增加了slave_parallel_type参数进行并发控制,用户可以选择database还是logical_lock,如果logical_lock实现了基于事务的多线程复制。

可以在线变更,不需要重启服务器

 

三:在Innodb中的新特性
1.。支持在线变更innodb_buffer_pool大小
2)增加innodb_buffer_pool导入导出功能
3)支持为Innodb建立表空间
支持create tablespace语法为一个表或者多个表建立公用表空间。

四:易用性
1.在MySQL 5.7 之前,如果用户输入了错误的SQL语句,按下 ctrl+c ,虽然能够”结束”SQL语句的运行,但是,也会退出当前会话,MySQL 5.7对这一违反直觉的地方进行了改进,不再退出会话。
2.可以explain一个正在运行的SQL,这对于DBA分析运行时间较长的语句将会非常有用
3.在MySQL 5.7中,performance_schema提供了更多监控信息,包括内存使用,MDL锁,存储过程等

 

你可能感兴趣的:(MySql5.7新特性)