从Oracle转到Mysql前需了解的50件事

摘要:
我个人的担忧如下:1。子查询优化性能较差2。复杂查询的弱处理4。性能优化工具和度量信息不足12。支持SMP,但如果每个处理器有超过4或8个内核,MySQL的可扩展性性能很差15。没有基于回滚的恢复功能,只有回滚前向恢复功能18。数据完整性检查非常薄弱,甚至基本的完整性约束都无法实现。

我本人比较关心的几点:

  1. 对子查询的优化表现不佳.

  2. 对复杂查询的处理较弱

  4. 性能优化工具与度量信息不足

  12. 支持 SMP (对称多处理器),但是如果每个处理器超过 4 或 8 个核(core)时,Mysql 的扩展性表现较差.

  15. 没有基于回滚(roll-back)的恢复功能,只有前滚(roll-forward)的恢复功能.

  18. 数据完整性检查非常薄弱,即使是基本的完整性约束,也往往不能执行。

  20. 只有一种表连接类型:嵌套循环连接(nested-loop),不支持排序-合并连接(sort-merge join)与散列连接(hash join).

  21. 大部分查询只能使用表上的单一索引;在某些情况下,会存在使用多个索引的查询,但是查询优化器通常会低估其成本,它们常常比表扫描还要慢.

  26. 每个存储引擎在行为表现、特性以及功能上都可能有很大差异.

  28. 默认的存储引擎(MyISAM)不支持事务,并且很容易损坏.

  30. 有些执行计划只支持特定的存储引擎.特定类型的 Count 查询,在这种存储引擎中执行很快,在另外一种存储引擎中可能会很慢.

  31. 执行计划并不是全局共享的,,仅仅在连接内部是共享的.

  33. 没有资源控制.一个完全未经授权的用户可以毫不费力地耗尽服务器的所有内存并使其崩溃,或者可以耗尽所有 CPU 资源.

  45. 复制(Replication)功能是异步的,并且有很大的局限性.例如,它是单线程的(single-threaded),因此一个处理能力更强的 Slave 的恢复速度也很难跟上处理能力相对较慢的 Master.

  46. Cluster 并不如想象的那么完美.或许我已经提过这一点,但是这一点值得再说一遍.

  47. 数据字典(INFORMATION_SCHEMA)功能很有限,并且访问速度很慢(在繁忙的系统上还很容易发生崩溃).

  48. 不支持在线的 Alter Table 操作.

  50. 类似于 ALTER TABLE 或 CREATE TABLE 一类的操作都是非事务性的.它们会提交未提交的事务,并且不能回滚也不能做灾难恢复 .Schame 被保存在文件系统上,这一点与它使用的存储引擎无关.

  从 Oracle 转到 Mysql 前需了解的 50 件事:

  1. 对子查询的优化表现不佳.

  2. 对复杂查询的处理较弱

  3. 查询优化器不够成熟

  4. 性能优化工具与度量信息不足

  5. 审计功能相对较弱

  6. 安全功能不成熟,甚至可以说很粗糙.没有用户组与角色的概念,没有回收权限的功能(仅仅可以授予权限).当一个用户从不同的主机/网络以同样地用户名/密码登录之后,可能被当作完全不同的用户来处理.没有类似于 Oracle 的内置的加密功能.

  7. 身份验证功能是完全内置的.不支持 LDAP,Active Directory 以及其它类似的外部身份验证功能.

  8. Mysql Cluster 可能与你的想象有较大差异.

  9. 存储过程与触发器的功能有限.

  10. 垂直扩展性较弱.

  11. 不支持 MPP (大规模并行处理).

  12. 支持 SMP (对称多处理器),但是如果每个处理器超过 4 或 8 个核(core)时,Mysql 的扩展性表现较差.

  13. 对于时间、日期、间隔等时间类型没有秒以下级别的存储类型.

  14. 可用来编写存储过程、触发器、计划事件以及存储函数的语言功能较弱.

  15. 没有基于回滚(roll-back)的恢复功能,只有前滚(roll-forward)的恢复功能.

  16. 不支持快照功能.

  17. 不支持数据库链(database link).有一种叫做 Federated 的存储引擎可以作为一个中转将查询语句传递到远程服务器的一个表上,不过,它功能很粗糙并且漏洞很多.

  18. 数据完整性检查非常薄弱,即使是基本的完整性约束,也往往不能执行。

  19. 优化查询语句执行计划的优化器提示非常少.

  20. 只有一种表连接类型:嵌套循环连接(nested-loop),不支持排序-合并连接(sort-merge join)与散列连接(hash join).

  21. 大部分查询只能使用表上的单一索引;在某些情况下,会存在使用多个索引的查询,但是查询优化器通常会低估其成本,它们常常比表扫描还要慢.

  22. 不支持位图索引(bitmap index).每种存储引擎都支持不同类型的索引.大部分存储引擎都支持B-Tree 索引.

  23. 管理工具较少,功能也不够成熟.

  24. 没有成熟能够令人满意的 IDE 工具与调试程序.可能不得不在文本编辑器中编写存储过程,并且通过往表(调试日志表)中插入记录的方式来做调试.

  25. 每个表都可以使用一种不同的存储引擎.

  26. 每个存储引擎在行为表现、特性以及功能上都可能有很大差异.

  27. 大部分存储引擎都不支持外键.

  28. 默认的存储引擎(MyISAM)不支持事务,并且很容易损坏.

  29. 最先进最流行的存储引擎 InnoDB 由 Oracle 拥有.

  30. 有些执行计划只支持特定的存储引擎.特定类型的 Count 查询,在这种存储引擎中执行很快,在另外一种存储引擎中可能会很慢.

  31. 执行计划并不是全局共享的,,仅仅在连接内部是共享的.

  32. 全文搜索功能有限, 只适用于非事务性存储引擎. Ditto 用于地理信息系统/空间类型和查询.

  33. 没有资源控制.一个完全未经授权的用户可以毫不费力地耗尽服务器的所有内存并使其崩溃,或者可以耗尽所有 CPU 资源.

  34. 没有集成商业智能(business intelligence), OLAP 多维数据集等软件包.

  35. 没有与 Grid Control 类似的工具(http://solutions.mysql.com/go.php?id=1296&t=s)

  36. 没有类似于 RAC 的功能.如果你问”如何使用 Mysql 来构造 RAC”,只能说你问错了问题.

  37. 不支持用户自定义类型或域(domain).

  38. 每个查询支持的连接的数量最大为 61.

  39. MySQL 支持的 SQL 语法(ANSI SQL 标准)的很小一部分.不支持递归查询、通用表表达式(Oracle 的 with 语句)或者窗口函数(分析函数).支持部分类似于 Merge 或者类似特性的 SQL 语法扩展,不过相对于 Oracle 来讲功能非常简单.

  40. 不支持功能列(基于计算或者表达式的列,Oracle11g 开始支持计算列,以及早期版本就支持虚列(rownum,rowid)).

  41. 不支持函数索引,只能在创建基于具体列的索引.

  42. 不支持物化视图.

  43. 不同的存储引擎之间,统计信息差别很大,并且所有的存储引擎支持的统计信息都只支持简单的基数(cardinality)与一定范围内的记录数(rows-in-a-range). 换句话说,数据分布统计信息是有限的.更新统计信息的机制也不多.

  44. 没有内置的负载均衡与故障切换机制.

  45. 复制(Replication)功能是异步的,并且有很大的局限性.例如,它是单线程的(single-threaded),因此一个处理能力更强的 Slave 的恢复速度也很难跟上处理能力相对较慢的 Master.

  46. Cluster 并不如想象的那么完美.或许我已经提过这一点,但是这一点值得再说一遍.

  47. 数据字典(INFORMATION_SCHEMA)功能很有限,并且访问速度很慢(在繁忙的系统上还很容易发生崩溃).

  48. 不支持在线的 Alter Table 操作.

  49. 不支持 Sequence.

  50. 类似于 ALTER TABLE 或 CREATE TABLE 一类的操作都是非事务性的.它们会提交未提交的事务,并且不能回滚也不能做灾难恢复 .Schame 被保存在文件系统上,这一点与它使用的存储引擎无关.

免责声明:文章转载自《从Oracle转到Mysql前需了解的50件事》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇如何清除XP的网络共享密码Golang Gin(上)下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

mysql如何修改所有的definer

mysql中的definer是什么,有什么作用? 我们在mysql创建view、trigger、function、procedure、event时都会定义一个Definer=‘xxx’,类似如下: CREATE ALGORITHM =UNDEFINED DEFINER = `root`@`%` SQL SECURITY DEFI...

十六、oracle 索引

一、管理索引-原理介绍索引是用于加速数据存取的数据对象。合理的使用索引可以大大降低i/o次数,从而提高数据访问性能。索引有很多种我们主要介绍常用的几种:为什么添加了索引后,会加快查询速度呢? 二、创建索引1)、单列索引单列索引是基于单个列所建立的索引语法:create index 索引名 on 表名(列名);eg、create index nameInd...

MySQL 8.0.17 版安装 || Windows

Mysql 8.0.17 安装 1.mysql下载 选择对应的下载地址:https://www.mysql.com/downloads/ 这里下载的是mysql-8.0.17-winx64.zip 2.解压 解压并创建my.ini和data文件夹 basedir替换成自己的解压路径 my.ini [client] # 设置mysql客户端默认字符集...

oracle之复杂查询(下):子查询

复杂查询(下):子查询8. 1 非关联子查询:返回的值可以被外部查询使用。子查询可以独立执行的(且仅执行一次)。8.1.1 单行单列子查询,子查询仅返回一个值,也称为标量子查询,采用单行比较运算符(>,<,=,<>,>=,<=)例:内部SELECT子句只返回一行结果SQL>select ename,salfrom...

ES:在线迁移集群索引,数据不丢失

一、背景 生产环境由于某些原因需要跨机房迁移ES集群,或者同机房原有集群中所有节点全部更换,期间ES索引要求完整,客户端请求中断不超过五分钟。 二、应用场景 1、同机房不同集群之间数据迁移; 2、跨机房不同集群之间数据迁移。 三、迁移方案A机房ES集群 --> B机房ES集群 1、迁移任务:假设A机房ES集群(3master、3data共三台物理...

es机器监控x-pack导致的监控存储过大的问题

https://blog.csdn.net/qq_36317804/article/details/103288642 最近发现磁盘的占用率趋高,打开可视化工具head查看了之后发现,es实例中生成了好多类似monitoring-es-6-2019.11.27这个的节点。 ##查询集群总的磁盘使用情况 curl -u elastic -XGET 'loca...