百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 优雅编程 > 正文

MySQL、Oracle、SqlServer的区别(mysql,sqlserver,oracle 区别)

sinye56 2024-09-22 08:41 4 浏览 0 评论

鉴于和数据库打交道日益频繁,遂决定写一篇关于Oracle、SqlServer、MySQL区别的个人观点。
MySQL是大学时的主要学习对象,但刚参加工作时转到了SqlServer,现在主要接触的是Oracle,由于其他数据库(例如DB2等)我并没用过,就不提及了。
事先说明:不一定对,欢迎指正,不吹不黑,不要骂我。  

  • 所属公司:
  • MySQL是由瑞典MySQL AB公司开发,目前属于 Oracle 旗下产品;
    Oracle是由美国ORACLE公司(甲骨文)开发的一组核心软件产品;
    SqlServer是由Microsoft、Sybase和Ashton-Tate三家公司共同开发的,目前主属Microsoft;  
  • sql语句的灵活性:
  • MySQL对sql语句更灵活,比如:limit功能,insert可以一次插入多行数据,select某些管理数据可以不加from;
    oracle对sql语句的感觉更加稳重传统一些;
    SqlServer对sql语句那绝了,两个成语概括:脚踏实地,步步为营; 
  • 保存数据的持久性:
  • MySQL是在数据库更新或者重启,则会丢失数据;
    Oracle把提交的sql操作线写入了在线联机日志文件中,保持到了磁盘上,可以随时恢复;
    SqlServer从2014之后,也拥有了完全持久和延迟持久特性;  
  • 提交方式:
  • MySQL默认是自动提交(变量autocommit为ON);
    oracle默认不自动提交,需要用户手动提交(commit);
    SqlServer默认是自动提交,用户可手动停止(KILL);
  • 对事务的支持:
  • MySQL在innodb存储引擎的行级锁的情况下才可支持事务;
    Oracle则完全支持事务;
    SqlServer在非自动提交时才可支持事务;  
  • 对并发性的支持:
  • MySQL以表级锁(行级锁依赖于表索引)为主,如果一个session的加锁时间过长,会让其他session无法更新此表中的数据,即“悲观并发控制”
    Oracle使用行级锁,对资源锁定的粒度要小很多,并且不依赖索引,对并发性的支持要好很多,即“乐观并发控制”
    SqlServer在表、表的分页、索引键以及单独的数据行上支配共享锁、排它锁、以及更新锁,简单地说:读取时用共享锁,修改时用排它锁,更新锁则是共享锁和排他锁的一种混合;  
  • 逻辑备份:
  • MySQL逻辑备份时要锁定数据,才能保证备份的数据是一致的,会影响正常业务;
    Oracle逻辑备份时不锁定数据,且备份的数据是一致;
    SqlServer逻辑备份时要锁定数据,才能保证备份的数据是一致的,会影响正常业务; 
  • 复制备份:
  • MySQL复制服务器配置简单,但主库出问题时,丛库有可能丢失一定的数据;
    Oracle既有推或拉式的传统数据复制,也有dataguard的双机或多机容灾机制,还有成熟的热备工具rman,主库出现问题时,可以自动切换备库到主库,但配置管理较复杂
    SqlServer的仅复制备份是独立于常规SQL Server备份序列的SQL Server备份。通常,进行备份会更改数据库并影响其后备份的还原方式。只用于:在不影响数据库总体备份和还原过程的情况下,为特殊目的而进行的备份。  
  • 性能诊断:
  • MySQL的诊断调优方法较少,主要有慢查询日志
    Oracle有各种成熟的性能诊断调优工具,能实现很多自动分析、诊断功能。比如awr、addm、sqltrace、tkproof等
    SqlServer性能检测工具有sql server profiler,性能调优工具有数据库引擎优化顾问,简单好用还炫酷; 
  • 权限与安全:
  • MySQL的用户与主机有关,更容易被仿冒主机及ip,有可乘之机,没什么意义;
    Oracle的用户和root用户权限彼此分离,权限与安全概念比较传统,中规中矩;
    SqlServer本机可用windows验证登录,远程则用SqlServer验证登录(即sa登录);  
  • 相关服务:
  • MySQL是轻量型数据库,并且免费开源,没有服务恢复数据;
    Oracle是重量型数据库,收费,Oracle公司对Oracle数据库有任何服务;
    SqlServer是重量型数据库,收费(与Java有合作),也有支持供应商;

总结得出:

MySQL优点:体积小、速度快、总体拥有成本低,开放源码,搭配“L(Linux)A(Apache)M(MySQL)P(PHP/Perl/Python)“或“LN(Nginx)MP”就可以建立起一个稳定、免费的网站系统,适合中小型网站。 
Oracle优点:使用方便、功能强大,可靠性好、安全性好、可移植性好、适应高吞吐量,适用于各类大、中、小、微机环境。
SqlServer优点:图形化用户界面,丰富的编程接口工具,与Windows NT完全集成,支持分布式的分区视图,适用于Win的Web技术的开发。
所以理性来讲,
这三个数据库各有所长。
用哪个数据库,完全取决你需要什么功能和服务。
当然啦,
也取决你有没有钱买你想要的服务

相关推荐

RHEL8和CentOS8怎么重启网络

本文主要讲解如何重启RHEL8或者CentOS8网络以及如何解决RHEL8和CentOS8系统的网络管理服务报错,当我们安装好RHEL8或者CentOS8,重启启动网络时,会出现以下报错:...

Linux 内、外网双网卡路由配置

1.路由信息的影响Linux系统中如果有多张网卡的情况下,如果路由信息配置不正确,...

Linux——centos7修改网卡名

修改网卡名这个操作可能平时用不太上,可作为了解。修改网卡默认名从ens33改成eth01.首先修改网卡配置文件名(建议将原配置文件进行备份)...

CentOS7下修改网卡名称为ethX的操作方法

?Linux操作系统的网卡设备的传统命名方式是eth0、eth1、eth2等,而CentOS7提供了不同的命名规则,默认是基于固件、拓扑、位置信息来分配。这样做的优点是命名全自动的、可预知的...

Linux 网卡名称enss33修改为eth0

一、CentOS修改/etc/sysconfig/grub文件(修改前先备份)为GRUB_CMDLINE_LINUX变量增加2个参数(net.ifnames=0biosdevname=0),修改完成...

CentOS下双网卡绑定,实现带宽飞速

方式一1.新建/etc/sysconfig/network-scripts/ifcfg-bond0文件DEVICE=bond0IPADDR=191.3.60.1NETMASK=255.255.2...

linux 双网卡双网段设置路由转发

背景网络情况linux双网卡:网卡A(ens3)和网卡B(...

Linux-VMware设置网卡保持激活

Linux系统只有在激活网卡的状态下才能去连接网络,进行网络通讯。修改配置文件(永久激活网卡)...

VMware虚拟机三种网络模式

01.VMware虚拟机三种网络模式由于linux目前很热门,越来越多的人在学习linux,但是买一台服务放家里来学习,实在是很浪费。那么如何解决这个问题?虚拟机软件是很好的选择,常用的虚拟机软件有v...

Rocky Linux 9/CentOS Stream 9修改网卡配置/自动修改主机名(实操)

推荐...

2023年最新版 linux克隆虚拟机 解决网卡uuid重复问题

问题描述1、克隆了虚拟机,两台虚拟机里面的ip以及网卡的uuid都是一样的2、ip好改,但是uuid如何改呢?解决问题1、每台主机应该保证网卡的UUID是唯一的,避免后面网络通信有问题...

Linux网卡的Vlan配置,你可能不了解的玩法

如果服务器上连的交换机端口已经预先设置了TRUNK,并允许特定的VLAN可以通过,那么服务器的网卡在配置时就必须指定所属的VLAN,否则就不通了,这种情形在虚拟化部署时较常见。例如在一个办公环境中,办...

Centos7 网卡绑定

1、切换到指定目录#备份网卡数据cd/etc/sysconfig/network-scriptscpifcfg-enp5s0f0ifcfg-enp5s0f0.bak...

Linux搭建nginx+keepalived 高可用(主备+双主模式)

一:keepalived简介反向代理及负载均衡参考:...

Linux下Route 路由指令使用详解

linuxroute命令用于显示和操作IP路由表。要实现两个不同子网之间的通信,需要一台连接两个网络的路由器,或者同时位于两个网络的网关来实现。在Linux系统中,设置路由通常是为了解决以下问题:该...

取消回复欢迎 发表评论: