mysql8.0和mysql5.7的区别是什么?
区别:mysql8.0的索引可以被隐藏和显示,当一个索引隐藏时,他不会被查询优化器所使用;2、mysql8.0新增了“SET PERSIST”命令;3、从mysql8.0开始,数据库的缺省编码将改为utf8mb4,包含了
<blockquote><p>区别:mysql8.0的索引可以被隐藏和显示,当一个索引隐藏时,他不会被查询优化器所使用;2、mysql8.0新增了“SET PERSIST”命令;3、从mysql8.0开始,数据库的缺省编码将改为utf8mb4,包含了所有emoji字符。</p></blockquote>
(推荐教程:mysql视频教程)
mysql8.0和mysql5.7的区别是
1. NoSql存储
Mysql从5.7 版本提供了NoSQL的存储功能,在8.0中这部分得到一些修改,不过这个在实际中用的极少
2.隐藏索引
隐藏索引的特性对于性能调试非常有用,在8.0 中,索引可以被隐藏和显示,当一个索引隐藏时,他不会被查询优化器所使用 也就是说可以隐藏一个索引,然后观察对数据库的影响.如果性能下降,就说明这个索引是有效的,于是将其”恢复显示”即可;如果数据库性能看不出变化,说明这个索引是多于的,可以删掉了
隐藏一个索引的语法
**注意:**当索引被隐藏时,他的内容仍然是和正常索引一样实时更新的,这个特性本身是专门为了优化调试而使用的,如果你长期隐藏一个索引,那还不如干掉,因为索引的存在会影响数据的插入更新和删除功能
3.设置持久化
MySQL 的设置可以在运行时通过 SET GLOBAL 命令来更改,但是这种更改只会临时生效,到下次启动时数据库又会从配置文件中读取。 MySQL 8 新增了 SET PERSIST 命令,例如: SET PERSIST max_connections = 500; MySQL 会将该命令的配置保存到数据目录下的 mysqld-auto.cnf 文件中,下次启动时会读取该文件,用其中的配置来覆盖缺省的配置文件。
4.UTF-8 编码
从 MySQL 8 开始,数据库的缺省编码将改为 utf8mb4,这个编码包含了所有 emoji 字符。多少年来我们使用 MySQL 都要在编码方面小心翼翼,生怕忘了将缺省的 latin 改掉而出现乱码问题。从此以后就不用担心了。
5.通用表表达式(Common Table Expressions)
复杂的查询会使用嵌入式表,例如:
更多编程相关知识,请访问:编程入门!!
以上就是mysql8.0和mysql5.7的区别是什么?的详细内容,更多请关注每日运维其它相关文章!