并发性是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:
mysql:对sql语句有很多非常实用而方便的扩展,比如limit功能,insert可以一次插入多行数据,select某些管理数据可以不加from。
oracle:在这方面感觉更加稳重传统一些。
oracle:既有推或拉式的传统数据复制,也有dataguard的双机或多机容灾机制,主库出现问题是,可以自动切换备库到主库,但配置管理较复杂。
mysql:复制服务器配置简单,但主库出问题时,丛库有可能丢失一定的数据。且需要手工切换丛库到主库。
oracle:有各种成熟的性能诊断调优工具,能实现很多自动分析、诊断功能。比如awr、addm、sqltrace、tkproof等
mysql:的诊断调优方法较少,主要有慢查询日志。
mysql:的用户与主机有关,感觉没有什么意义,另外更容易被仿冒主机及ip有可乘之机。
oracle:的权限与安全概念比较传统,中规中矩。
oracle:的分区表和分区索引功能很成熟,可以提高用户访问db的体验。
mysql:的分区表还不太成熟稳定。
转载自【http://blog.csdn.net/u012515285/article/details/51395055】1 秒杀业务分析正常电子商务流程(1)查询商品;(2)创建订单;(3)扣减库存;(4)更新订单;(5)付款;(6)卖家发货秒杀业务的特性(1)低廉价格;(2)大幅推广;(3)瞬时售空;(4)一般是定时上架;(5)时间短、瞬时并发量高;2 秒杀技术挑...
1.北京实时公交#https://github.com/wong2/beijing_buspip install -r requirements.txt 安装依赖python manage.py build_cache 获取离线数据,建立本地缓存#项目自带了一个终端中的查询工具作为例子,运行: python manage.py cli>>> from beij...
高性能网络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
技术这种东西,靠的就是积累,所以我决定将我这名小小程序猿的成长点滴记录下来,经常看看!最近两天做了系统的新需求,就是限定身份,注册时间,并且对参与人员给予一定显示。这里首先牵涉到一个同步登陆的动作,登录主系统之后,通过在html中写入javascript代码调用另外连个子系统的登录接口,完成三个系统的同步登陆。这个过程主要是参数的传递,登录子系统的过程也可以通过直接调用F12中的URL来调试。
因为之前在网上找这个资源的时候发现都是转载的一个帖子,别人自己收集了完了还要收钱,于是在此分享给大家供大家学习与交流。下面是书的目录,文章结尾有链接。封面 1版权声明 4作者序 5前言 6目录 8Part01 开始网络编程 10第1章 理解网络编程和套接字 121.1 理解网络编程和套接字 121.2 基于Linux的文件操作 191.3 基于Windows平台的实现 251.4 基于Windows的套接字相关函数及示例 281.5 习题 34第2章 套接字类型与协议设置 362
一、问题启动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
前置知识:不同计算机程序之间的数据传输应用程序中的数据都是从程序所在计算机内存中读取的。内存中的数据是从硬盘读取或者网络传输过来的不同计算机程序数据传输需要经过七层协议物理连接介质才能到达目标程序sockt 套接字json.dump/dumps 只是把数据类型序列化成字符串要想用来文件传输,还需要encode 给它编码成二进制数据才能传输不用pickle是因为要和...
一、安装npm install react-native-camera --savereact-native link react-native-camera二、配置(IOS)三、使用只需import { RNCamera } from react-native-camera 模块中 取出标签。引用标签:<RNCamera ref={ref => {...
今天编译了一下php7.4 因为我的libxml 是自己编译按照以前的版本方式 安装时指定--with-libxml-dir=/opt/libxml2 一下编译的libxml 目录还是不可以https://bugs.php.net/bug.php?id=79135&thanks=2 去php官方提了编译失败的问题,感谢大佬回答大佬说 php 7.4 是依赖于p...
首先想到的就是最笨的方法,暴力搜索,但是好像通过不了,超出时间限制,看了别人的代码,才知道大神真的是太多太多。class Solution {public: string longestPalindrome(string s) { string res="";//存放结果 string temp="";//存放子串 for(int i=0...
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在使用pandas读取CSV文件的时候,报了上述错误,这是缓冲区溢出错误,造成这种错误的原因是CSV文件中每行使用了 \r ,也就是回车符。解决方案就是给 read_csv 添加参数 line...