Oracle与MySQl对比_oracle mysql对比_阿肯那顿的博客-程序员秘密

技术标签: oracle  mysql  数据库  

并发性

并发性是oltp数据库最重要的特性,但并发涉及到资源的获取、共享与锁定。

mysql:以表级锁为主,对资源锁定的粒度很大,如果一个session对一个表加锁时间过长,会让其他session无法更新此表中的数据。
虽然InnoDB引擎的表可以用行级锁,但这个行级锁的机制依赖于表的索引,如果表没有索引,或者sql语句没有使用索引,那么仍然使用表级锁。

oracle:使用行级锁,对资源锁定的粒度要小很多,只是锁定sql需要的资源,并且加锁是在数据库中的数据行上,不依赖与索引。所以oracle对并发性的支持要好很多。

一致性

oracle:支持serializable的隔离级别,可以实现最高级别的读一致性。每个session提交后其他session才能看到提交的更改。oracle通过在undo表空间中构造多版本数据块来实现读一致性,每个session查询时,如果对应的数据块发生变化,oracle会在undo表空间中为这个session构造它查询时的旧的数据块。

mysql:没有类似oracle的构造多版本数据块的机制,只支持read commited的隔离级别。一个session读取数据时,其他session不能更改数据,但可以在表最后插入数据。
session更新数据时,要加上排它锁,其他session无法访问数据。

事务

oracle:很早就完全支持事务。

mysql:在innodb存储引擎的行级锁的情况下才支持事务。

数据持久性

oracle:保证提交的数据均可恢复,因为oracle把提交的sql操作线写入了在线联机日志文件中,保持到了磁盘上,如果出现数据库或主机异常重启,重启后oracle可以考联机在线日志恢复客户提交的数据。

mysql:默认提交sql语句,但如果更新过程中出现db或主机重启的问题,也许会丢失数据。

提交方式

oracle:默认不自动提交,需要用户手动提交。
mysql:默认是自动提交。

逻辑备份

oracle:逻辑备份时不锁定数据,且备份的数据是一致的。
mysql:逻辑备份时要锁定数据,才能保证备份的数据是一致的,影响业务正常的dml使用。

热备份

oracle:有成熟的热备工具rman,热备时,不影响用户使用数据库。即使备份的数据库不一致,也可以在恢复时通过归档日志和联机重做日志进行一致的回复。

mysql:

  • myisam的引擎,用mysql自带的mysqlhostcopy热备时,需要给表加读锁,影响dml操作。
  • innodb的引擎,它会备份innodb的表和索引,但是不会备份.frm文件。用ibbackup备份时,会有一个日志文件记录备份期间的数据变化,因此可以不用锁表,不影响其他用户使用数据库。但此工具是收费的。
    innobackup是结合ibbackup使用的一个脚本,他会协助对.frm文件的备份。

sql语句的扩展和灵活性

mysql:对sql语句有很多非常实用而方便的扩展,比如limit功能,insert可以一次插入多行数据,select某些管理数据可以不加from。
oracle:在这方面感觉更加稳重传统一些。

复制

oracle:既有推或拉式的传统数据复制,也有dataguard的双机或多机容灾机制,主库出现问题是,可以自动切换备库到主库,但配置管理较复杂。
mysql:复制服务器配置简单,但主库出问题时,丛库有可能丢失一定的数据。且需要手工切换丛库到主库。

性能诊断

oracle:有各种成熟的性能诊断调优工具,能实现很多自动分析、诊断功能。比如awr、addm、sqltrace、tkproof等
mysql:的诊断调优方法较少,主要有慢查询日志。

权限与安全

mysql:的用户与主机有关,感觉没有什么意义,另外更容易被仿冒主机及ip有可乘之机。
oracle:的权限与安全概念比较传统,中规中矩。

分区表和分区索引

oracle:的分区表和分区索引功能很成熟,可以提高用户访问db的体验。
mysql:的分区表还不太成熟稳定。

语法区别:

  1. 自动增长的数据类型处理
    MYSQL:有自动增长的数据类型,插入记录时不用操作此字段,会自动获得数据值。
    ORACLE:没有自动增长的数据类型,需要建立一个自动增长的序列号,插入记录时要把序列号的下一个值赋于此字段。
  2. 单引号的处理
    MYSQL:里可以用双引号包起字符串
    ORACLE:里只可以用单引号包起字符串。在插入和修改字符串前必须做单引号的替换:把所有出现的一个单引号替换成两个单引号。
  3. 翻页的SQL语句的处理
    MYSQL:处理翻页的SQL语句比较简单,用LIMIT 开始位置, 记录个数;PHP里还可以用SEEK定位到结果集的位置。
    ORACLE:处理翻页的SQL语句就比较繁琐了。每个结果集只有一个ROWNUM字段标明它的位置, 并且只能用ROWNUM<100, 不能用ROWNUM>80。
  4. 长字符串的处理
    长字符串的处理ORACLE也有它特殊的地方。INSERT和UPDATE时最大可操作的字符串长度小于等于4000个单字节, 如果要插入更长的字符串,请考虑字段用CLOB类型,方法借用ORACLE里自带的DBMS_LOB程序包。插入修改记录前一定要做进行非空和长度判断,不能为空的字段值和超出长度字段值都应该提出警告,返回上次操作。
  5. 空字符的处理
    MYSQL:的非空字段也有空的内容
    ORACLE:里定义了非空字段就不容许有空的内容。
    按MYSQL的NOT NULL来定义ORACLE表结构, 导数据的时候会产生错误。因此导数据时要对空字符进行判断,如果为NULL或空字符,需要把它改成一个空格的字符串。
  6. 字符串的模糊比较
    MYSQL:里用 字段名 like ‘%字符串%’
    ORACLE:里也可以用 字段名 like ‘%字符串%’ 但这种方法不能使用索引, 速度不快,用字符串比较函数 instr(字段名,’字符串’)>0 会得到更精确的查找结果。
  7. 程序和函数里,操作数据库的工作完成后请注意结果集和指针的释放。
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/wy0123/article/details/79435829

智能推荐

【转载】秒杀系统架构分析与实现_小凡软件的博客-程序员秘密

转载自【http://blog.csdn.net/u012515285/article/details/51395055】1 秒杀业务分析正常电子商务流程(1)查询商品;(2)创建订单;(3)扣减库存;(4)更新订单;(5)付款;(6)卖家发货秒杀业务的特性(1)低廉价格;(2)大幅推广;(3)瞬时售空;(4)一般是定时上架;(5)时间短、瞬时并发量高;2 秒杀技术挑...

python各种有趣的模块_taczeng的博客-程序员秘密

1.北京实时公交#https://github.com/wong2/beijing_buspip install -r requirements.txt 安装依赖python manage.py build_cache 获取离线数据,建立本地缓存#项目自带了一个终端中的查询工具作为例子,运行: python manage.py cli&gt;&gt;&gt; from beij...

高性能网络I/O框架-netmap源码分析(2) http://blog.chinaunix.net/uid-23629988-id-3608622.html_1255645的博客-程序员秘密

高性能网络I/O框架-netmap源码分析(2) 2013-04-21 22:00:55分类: LINUX作者:[email protected]博客:blog.focus-linux.net linuxfocus.blog.chinaunix.net微博:weibo.com/glinuxerQQ技术群:4367710

2014-12-09_wowo_zZ的博客-程序员秘密

技术这种东西,靠的就是积累,所以我决定将我这名小小程序猿的成长点滴记录下来,经常看看!最近两天做了系统的新需求,就是限定身份,注册时间,并且对参与人员给予一定显示。这里首先牵涉到一个同步登陆的动作,登录主系统之后,通过在html中写入javascript代码调用另外连个子系统的登录接口,完成三个系统的同步登陆。这个过程主要是参数的传递,登录子系统的过程也可以通过直接调用F12中的URL来调试。

《TCPIP网络编程(尹圣雨)》PDF+源代码+目录;文章最底下有链接_tcpip网络编程pdf_普通网友的博客-程序员秘密

因为之前在网上找这个资源的时候发现都是转载的一个帖子,别人自己收集了完了还要收钱,于是在此分享给大家供大家学习与交流。下面是书的目录,文章结尾有链接。封面 1版权声明 4作者序 5前言 6目录 8Part01 开始网络编程 10第1章 理解网络编程和套接字 121.1 理解网络编程和套接字 121.2 基于Linux的文件操作 191.3 基于Windows平台的实现 251.4 基于Windows的套接字相关函数及示例 281.5 习题 34第2章 套接字类型与协议设置 362

Can't load AMD 64-bit .dll on a IA 32-bit platform错误的解决办法_晓太白的博客-程序员秘密

一、问题启动Tomcat 出现 Can’t load AMD 64-bit .dll on a IA 32-bit platform错误的解决办法二、错误信息Can't load AMD 64-bit .dll on a IA 32-bit platform三、解决办法因为本机JDK版本为32位的,而Tomcat为64位版本,所以启动出错,删除本地JDK版本,然后去官网 http://www.or

随便推点

8.7 day28 网络编程 socket套接字 半连接池 通信循环 粘包问题 struct模块 Mac报错_weixin_30613343的博客-程序员秘密

前置知识:不同计算机程序之间的数据传输应用程序中的数据都是从程序所在计算机内存中读取的。内存中的数据是从硬盘读取或者网络传输过来的不同计算机程序数据传输需要经过七层协议物理连接介质才能到达目标程序sockt 套接字json.dump/dumps 只是把数据类型序列化成字符串要想用来文件传输,还需要encode 给它编码成二进制数据才能传输不用pickle是因为要和...

React Native 基于react-native-camera实现扫码功能_rncamera_shalihcy的博客-程序员秘密

一、安装npm install react-native-camera --savereact-native link react-native-camera二、配置(IOS)三、使用只需import { RNCamera } from react-native-camera 模块中 取出标签。引用标签:&lt;RNCamera ref={ref =&gt; {...

php7.4.1 configure: error: Package requirements (libxml-2.0 >= 2.7.6) were not met:_飞飞飞Boy的博客-程序员秘密

今天编译了一下php7.4 因为我的libxml 是自己编译按照以前的版本方式 安装时指定--with-libxml-dir=/opt/libxml2 一下编译的libxml 目录还是不可以https://bugs.php.net/bug.php?id=79135&amp;thanks=2 去php官方提了编译失败的问题,感谢大佬回答大佬说 php 7.4 是依赖于p...

leetcode最长回文数_灿烂的人生的博客-程序员秘密

首先想到的就是最笨的方法,暴力搜索,但是好像通过不了,超出时间限制,看了别人的代码,才知道大神真的是太多太多。class Solution {public: string longestPalindrome(string s) { string res="";//存放结果 string temp="";//存放子串 for(int i=0...

学习笔记之深入浅出MFC 第9章 仿真MFC之二_walkman_lfq的博客-程序员秘密

RTTI(执行期类型识别)在前面章节中我们介绍过Visual C++4.0支持RTTI,重点不外乎是:1、编译时需选用/GR(/GR的意思是enable C++ RTTI)2、包含typeinfo.h3、使用新的typeid运算符。其实,MFC在编译器支持RTTI之前,就有了这项能力。我们现在要以相同的手法,在Console程序中仿真出来。我希望我的类库具备IsKindOf的能

ParserError: Error tokenizing data. C error: Buffer overflow caught - possible malformed input file_TZmin的博客-程序员秘密

报错:ParserError: Error tokenizing data. C error: Buffer overflow caught - possible malformed input file在使用pandas读取CSV文件的时候,报了上述错误,这是缓冲区溢出错误,造成这种错误的原因是CSV文件中每行使用了 \r ,也就是回车符。解决方案就是给 read_csv 添加参数 line...

推荐文章

热门文章

相关标签