1、性能卓越,做事稳定,很少涌现非常宕机;
2、开放源代码无版本制约,自主性及利用本钱低;
3、历史悠久,社区和用户非常生动,碰着问题及时寻求帮助;

4、软件体积小,安装利用大略且易于掩护,掩护本钱低;品牌口碑效应;
5、支持多种OS,供应多种API接口,支持多种开拓措辞,对盛行的PHP,Java很好的支持
MySQL的缺陷
1、MySQL最大的缺陷是其安全系统,紧张是繁芜而非标准,其余只有到调用mysqladmin来重读用户权限才会发生改变;
2、MySQL的另一个紧张的路子之一是缺少标准的RI(Referential Integrity-RI)机制,RI限定的缺少(在给定字段域上的一种固定的范围限定)可以通过大量的数据类型来补偿;
3、MySQL不支持热备份;
Oracle的特点
1、兼容性:Oracle产品采取标准SQL,并经由美国u构架标准技能所(NIST)测试,与IBM SQL/DS、DB2、INGRES、IDMS/R等兼容。
2、可移植性:Oracle的产品可运行于很宽范围的硬件与操作系统平台上。可以安装在多种 大、中、小型机上,可在多种操作系统下事情。
3、可联结性:Oracle能与多种通讯网络相连,支持各种协议。
4、高生产率:Oracle产品供应了多种开拓工具,能极大地方利用户进行进一步的开拓。
5、开放性:Oracle良好的兼容性、可移植性、可连接性和高生产率使Oracle RDBMS具有良好的开放性。
Oracle的缺陷
1、对硬件哀求很高;
2、价格比较昂贵;
3、管理掩护麻烦一些;
4、操作比较繁芜,须要技能含量高;
mysql和oracle的差异有:
1、Oracle数据库是一个工具关系数据库管理系统,要收费;MySQL是一个开源的关系数据库管理系统,是免费的;
2、数据库安全性的差异;
3、工具名称的差异;
4、临时表处理办法上的差异等等。
MySQL和Oracle都是盛行的关系数据库管理系统(RDBMS),在世界各地广泛利用;大多数数据库以类似的办法事情,但MySQL和Oracle的这里和那里总是存在一些差异的。本篇文章就给大家比较Oracle和MySQL,先容Oracle和MySQL之间的差异,希望对你们有所帮助。
MySQL和Oracle有什么差异?两个数据库的特性是不同的,以是与Oracle比较,MySQL的利用办法不同;与MySQL比较,Oracle的利用情形有所不同。它们的特点也是不同的。下面我们就来详细看看MySQL和Oracle的差异有哪些。
0、宏不雅观上:
1、Oracle是大型的数据库而Mysql是中小型数据库;Mysql是开源的,Oracle是收费的,且价格昂贵。
2、Oracle支持大并发,大访问量,是OLTP的最好的工具。
3、安装占用的内存也是有差别,Mysql安装完成之后占用的内存远远小于Oracle所占用的内存,并且Oracle越用所占内存也会变多。
1、实质的差异
Oracle数据库是一个工具关系数据库管理系统(ORDBMS)。它常日被称为Oracle RDBMS或简称为Oracle,是一个收费的数据库。
MySQL是一个开源的关系数据库管理系统(RDBMS)。它是天下上利用最多的RDBMS,作为做事器运行,供应对多个数据库的多用户访问。它是一个开源、免费的数据库。
2、数据库安全性
MySQL利用三个参数来验证用户,即用户名,密码和位置;Oracle利用了许多安全功能,如用户名,密码,配置文件,本地身份验证,外部身份验证,高等安全增强功能等。
3、SQL语法的差异
Oracle的SQL语法与MySQL有很大不同。Oracle为称为PL / SQL的编程措辞供应了更大的灵巧性。Oracle的SQL Plus工具供应了比MySQL更多的命令,用于天生报表输出和变量定义。
4、存储上的差异:
与Oracle比较,MySQL没有表空间,角色管理,快照,同义词和包以及自动存储管理。
5、工具名称的差异:
虽然某些模式工具名称在Oracle和MySQL中都不区分大小写,例如列,存储过程,索引等。但在某些情形下,两个数据库之间的区分大小写是不同的。
Oracle对所有工具名称都不区分大小写;而某些MySQL工具名称(如数据库和表)区分大小写(取决于底层操作系统)。
6、运行程序和外部程序支持:
Oracle数据库支持从数据库内部编写,编译和实行的几种编程措辞。此外,为了传输数据,Oracle数据库利用XML。
MySQL不支持在系统内实行其他措辞,也不支持XML。
7、MySQL和Oracle的字符数据类型比较:
两个数据库中支持的字符类型存在一些差异。对付字符类型,MySQL具有CHAR和VARCHAR,最大长度许可为65,535字节(CHAR最多可以为255字节,VARCHAR为65.535字节)。
而,Oracle支持四种字符类型,即CHAR,NCHAR,VARCHAR2和NVARCHAR2; 所有四种字符类型都须要至少1个字节长; CHAR和NCHAR最大可以是2000个字节,NVARCHAR2和VARCHAR2的最大限定是4000个字节。可能会在最新版本中进行扩展。
8、MySQL和Oracle的额外功能比较:
MySQL数据库不支持其做事器上的任何功能,如Audit Vault。另一方面,Oracle支持其数据库做事器上的几个扩展和程序,例如Active Data Guard,Audit Vault,Partitioning和Data Mining等。
9、临时表的差异:
Oracle和MySQL以不同办法处理临时表。
在MySQL中,临时表是仅对当前用户会话可见的数据库工具,并且一旦会话结束,这些表将自动删除。
Oracle中临时表的定义与MySQL略有不同,由于临时表一旦创建就会存在,直到它们被显式删除,并且对具有适当权限的所有会话都可见。但是,临时表中的数据仅对将数据插入表中的用户会话可见,并且数据可能在事务或用户会话期间持续存在。
10、MySQL和Oracle中的备份类型:
Oracle供应不同类型的备份工具,如冷备份,热备份,导出,导入,数据泵。Oracle供应了最盛行的称为Recovery Manager(RMAN)的备份实用程序。利用RMAN,我们可以利用极少的命令或存储脚本自动化我们的备份调度和规复数据库。
MySQL有mysqldump和mysqlhotcopy备份工具。在MySQL中没有像RMAN这样的实用程序。
11、Oracle和MySQL的数据库管理:
在数据库管理部分Oracle DBA比MySQL DBA更有收益。与MySQL比较,Oracle DBA有很多可用的范围。
12、数据库的认证:
MySQL认证比Oracle认证更随意马虎。
与Oracle(设置为利用数据库身份验证时)和大多数仅利用用户名和密码对用户进行身份验证的其他数据库不同,MySQL在对用户进行身份验证location时会利用其他参数。此location参数常日是主机名,IP地址或通配符。
利用此附加参数,MySQL可以进一步将用户对数据库的访问限定为域中的特定主机或主机。此外,这还许可根据进行连接的主机为用户逼迫履行不同的密和权限集。因此,从abc.com登录的用户scott可能与从xyz.com登录的用户scott相同或不同。
MySQL与Oracle的运用差异
1、主键的利用:
MySQL:一样平常利用自动增长类型,在创建表的时候只要指定表的主键为auto increment,插入记录时就不须要再为主键添加记录了,主键会自动增长;
Oracle:没有自动增长,主键一样平常利用序列,插入记录时将序列号的下一值赋给该字段即可,只是ORM框架只是须要native主键天生策略即可。
2、长字符串的处理
长字符串的处理ORACLE也有它分外的地方。INSERT和UPDATE是最大可操作的字符串长度小于即是4000个单字符,
如果要插入更长的字符串,请考虑字段用CLOB类型,方法借用ORACLE里自带的DBMS_LOB程序包。插入修正记录前一定要做进行非空和长度判断,不能为空的字段值和超出长度值都该当提出警告,返回上次操作。
3、模糊查询的比较
MySQL:用字段名like%‘字符串%’
Oracle:也可以用字段名like%'字符串%'但这种方法不能利用索引,速率烦懑,用字符串比较函数
isnert(字段名,‘字符串’)>0会得到更精确的查找结果
4、空字符串的比较:
MySQL的非空字段也有空的内容,Oracle里定义了非空字段就不容许有空的内容。按MySQL的not null来定义Oracle表构造。
到数据的时候就会产生缺点。因此导数据是对空字符进行判断,如果为Null或空字符,须要把它改成一个空格的字符串。
5、单引号的处理
MySQL里可以用双引号包起字符串,Oracle里只可以用单引号包起字符串,在插入和修正字符串前必须做单引的更换;
把所有涌现的一个单引号更换成两个单引号