mysql数据库对比?mysql如何比对两个数据库表结构的方法
大家好,今天小编来为大家解答以下的问题,关于mysql数据库对比,mysql如何比对两个数据库表结构的方法这个很多人还不知道,现在让我们一起来看看吧!
几种常用数据库比较_MySQL
目前,商品化的数据库管理系统以关系型数据库为主导产品,技术比较成熟。面向对象的数据库管理系统虽然技术先进,数据库易于开发、维护,但尚未有成熟的产品。国际国内的主导关系型数据库管理系统有Oracle、Sybase、INFORMIX和INGRES。这些产品都支持多平台,如 UNIX、VMS、Windows,但支持的程度不一样。IBM的DB2也是成熟的关系型数据库。但是,DB2是内嵌于IBM的AS/400系列机中,只支持OS/400操作系统。
1.MySQL
MySQL是最受欢迎的开源SQL数据库管理系统,它由 MySQL AB开发、发布和支持。MySQL AB是一家基于MySQL开发人员的商业公司,它是一家使用了一种成功的商业模式来结合开源价值和方法论的第二代开源公司。MySQL是MySQL AB的注册商标。
MySQL是一个快速的、多线程、多用户和健壮的SQL数据库服务器。MySQL服务器支持关键任务、重负载生产系统的使用,也可以将它嵌入到一个大配置(mass- deployed)的软件中去。
与其他数据库管理系统相比,MySQL具有以下优势:
(1)MySQL是一个关系数据库管理系统。
(2)MySQL是开源的。
(3)MySQL服务器是一个快速的、可靠的和易于使用的数据库服务器。
(4)MySQL服务器工作在客户/服务器或嵌入系统中。
(5)有大量的MySQL软件可以使用。
2.SQL Server
SQL Server是由微软开发的数据库管理系统,是Web上最流行的用于存储数据的数据库,它已广泛用于电子商务、银行、保险、电力等与数据库有关的行业。
目前最新版本是SQL Server 2005,它只能在Windows上运行,操作系统的系统稳定性对数据库十分重要。并行实施和共存模型并不成熟,很难处理日益增多的用户数和数据卷,伸缩性有限。
SQL Server提供了众多的Web和电子商务功能,如对XML和Internet标准的丰富支持,通过Web对数据进行轻松安全的访问,具有强大的、灵活的、基于Web的和安全的应用程序管理等。而且,由于其易操作性及其友好的操作界面,深受广大用户的喜爱。
3.Oracle
提起数据库,第一个想到的公司,一般都会是Oracle(甲骨文)。该公司成立于1977年,最初是一家专门开发数据库的公司。Oracle在数据库领域一直处于领先地位。 1984年,首先将关系数据库转到了桌面计算机上。然后,Oracle5率先推出了分布式数据库、客户/服务器结构等崭新的概念。Oracle 6首创行锁定模式以及对称多处理计算机的支持……最新的Oracle 8主要增加了对象技术,成为关系—对象数据库系统。目前,Oracle产品覆盖了大、中、小型机等几十种机型,Oracle数据库成为世界上使用最广泛的关系数据系统之一。
Oracle数据库产品具有以下优良特性。
(1)兼容性
Oracle产品采用标准SQL,并经过美国国家标准技术所(NIST)测试。与IBM SQL/DS、DB2、INGRES、IDMS/R等兼容。
(2)可移植性
Oracle的产品可运行于很宽范围的硬件与操作系统平台上。可以安装在70种以上不同的大、中、小型机上;可在VMS、DOS、UNIX、Windows等多种操作系统下工作。
(3)可联结性
Oracle能与多种通讯网络相连,支持各种协议(TCP/IP、DECnet、LU6.2等)。
(4)高生产率
Oracle产品提供了多种开发工具,能极大地方便用户进行进一步的开发。
(5)开放性
Oracle良好的兼容性、可移植性、可连接性和高生产率使Oracle RDBMS具有良好的开放性。
4.Sybase
1984年,Mark B. Hiffman和Robert Epstern创建了Sybase公司,并在1987年推出了Sybase数据库产品。Sybase主要有三种版本:一是UNIX操作系统下运行的版本;二是Novell Netware环境下运行的版本;三是Windows NT环境下运行的版本。对UNIX操作系统,目前应用最广泛的是SYBASE 10及SYABSE 11 for SCO UNIX。
Sybase数据库的特点:
(1)它是基于客户/服务器体系结构的数据库。
(2)它是真正开放的数据库。
(3)它是一种高性能的数据库。
5.DB2
DB2是内嵌于IBM的AS/400系统上的数据库管理系统,直接由硬件支持。它支持标准的SQL语言,具有与异种数据库相连的GATEWAY。因此它具有速度快、可靠性好的优点。但是,只有硬件平台选择了IBM的AS/400,才能选择使用DB2数据库管理系统。
DB2能在所有主流平台上运行(包括Windows),最适于海量数据。
DB2在企业级的应用最为广泛,在全球的500家最大的企业中,几乎85%以上都用DB2数据库服务器,而国内到1997年约占5%。
除此之外,还有微软的 Access数据库、FoxPro数据库等。既然现在有这么多的数据库系统,那么在游戏编程时应该选择什么样的数据库呢?首要的原则就是根据实际需要,另一方面还要考虑游戏开发预算。现在常用的数据库有:SQL Server、My SQL、Oracle、FoxPro。其中MySQL是一个完全免费的数据库系统,其功能也具备了标准数据库的功能,因此,在独立制作时,建议使用。 Oracle虽然功能强劲,但它毕竟是为商业用途而存在的,目前很少在游戏中使用到。
如何比较mysql数据库的表结构和表内容的差异
DatabaseCompare可以比较数据库表结构、视图、存储过程、触发器等不同的可视化工具。
比较两个数据库全部表结构的差异,包括表名、存储引擎、字符集、注释的不同,以及每张表中的字段名、数据类型、字符集、默认值、注释的不同,还有索引的不同、字段顺序的不同。比较两个数据库全部视图的差异。比较两个数据库全部存储过程的差异。比较两个数据库全部触发器的差异。支持MySQL、MS SQL Server、SQLite的比较。
ampnmp.com/database-compare/
mysql如何比对两个数据库表结构的方法
在开发及调试的过程中,需要比对新旧代码的差异,我们可以使用git/svn等版本控制工具进行比对。而不同版本的数据库表结构也存在差异,我们同样需要比对差异及获取更新结构的sql语句。
例如同一套代码,在开发环境正常,在测试环境出现问题,这时除了检查服务器设置,还需要比对开发环境与测试环境的数据库表结构是否存在差异。找到差异后需要更新测试环境数据库表结构直到开发与测试环境的数据库表结构一致。
我们可以使用mysqldiff工具来实现比对数据库表结构及获取更新结构的sql语句。
1.mysqldiff安装方法
mysqldiff工具在mysql-utilities软件包中,而运行mysql-utilities需要安装依赖mysql-connector-python
mysql-connector-python安装
下载地址:https://dev.mysql.com/downloads/connector/python/
mysql-utilities安装
下载地址:https://downloads.mysql.com/archives/utilities/
因本人使用的是mac系统,可以直接使用brew安装即可。
brew install caskroom/cask/mysql-connector-python
brew install caskroom/cask/mysql-utilities
安装以后执行查看版本命令,如果能显示版本表示安装成功
mysqldiff--version
MySQL Utilities mysqldiff version 1.6.5
License type: GPLv2
2.mysqldiff使用方法
命令:
mysqldiff--server1=root@host1--server2=root@host2--difftype=sql db1.table1:dbx.table3
参数说明:
--server1指定数据库1
--server2指定数据库2
比对可以针对单个数据库,仅指定server1选项可以比较同一个库中的不同表结构。
--difftype差异信息的显示方式
unified(default)
显示统一格式输出
context
显示上下文格式输出
differ
显示不同样式的格式输出
sql
显示SQL转换语句输出
如果要获取sql转换语句,使用sql这种显示方式显示最适合。
--character-set指定字符集
--changes-for用于指定要转换的对象,也就是生成差异的方向,默认是server1
--changes-for=server1表示server1要转为server2的结构,server2为主。
--changes-for=server2表示server2要转为server1的结构,server1为主。
--skip-table-options忽略AUTO_INCREMENT, ENGINE, CHARSET的差异。
--version查看版本
更多mysqldiff的参数使用方法可参考官方文档:
https://dev.mysql.com/doc/mysql-utilities/1.5/en/mysqldiff.html
3.实例
创建测试数据库表及数据
create database testa;
create database testb;
use testa;
CREATE TABLE `tba`(
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`name` varchar(25) NOT NULL,
`age` int(10) unsigned NOT NULL,
`addtime` int(10) unsigned NOT NULL,
PRIMARY KEY(`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1001 DEFAULT CHARSET=utf8;
insert into `tba`(name,age,addtime) values('fdipzone',18,1514089188);
use testb;
CREATE TABLE `tbb`(
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`name` varchar(20) NOT NULL,
`age` int(10) NOT NULL,
`addtime` int(10) NOT NULL,
PRIMARY KEY(`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
insert into `tbb`(name,age,addtime) values('fdipzone',19,1514089188);
执行差异比对,设置server1为主,server2要转为server1数据库表结构
mysqldiff--server1=root@localhost--server2=root@localhost--changes-for=server2--difftype=sql testa.tba:testb.tbb;
# server1 on localhost:... connected.
# server2 on localhost:... connected.
# Comparing testa.tba to testb.tbb [FAIL]
# Transformation for--changes-for=server2:
#
ALTER TABLE `testb`.`tbb`
CHANGE COLUMN addtime addtime int(10) unsigned NOT NULL,
CHANGE COLUMN age age int(10) unsigned NOT NULL,
CHANGE COLUMN name name varchar(25) NOT NULL,
RENAME TO testa.tba
, AUTO_INCREMENT=1002;
# Compare failed. One or more differences found.
执行mysqldiff返回的更新sql语句
mysql> ALTER TABLE `testb`.`tbb`
-> CHANGE COLUMN addtime addtime int(10) unsigned NOT NULL,
-> CHANGE COLUMN age age int(10) unsigned NOT NULL,
-> CHANGE COLUMN name name varchar(25) NOT NULL;
Query OK, 0 rows affected(0.03 sec)
再次执行mysqldiff进行比对,结构没有差异,只有AUTO_INCREMENT存在差异
mysqldiff--server1=root@localhost--server2=root@localhost--changes-for=server2--difftype=sql testa.tba:testb.tbb;
# server1 on localhost:... connected.
# server2 on localhost:... connected.
# Comparing testa.tba to testb.tbb [FAIL]
# Transformation for--changes-for=server2:
#
ALTER TABLE `testb`.`tbb`
RENAME TO testa.tba
, AUTO_INCREMENT=1002;
# Compare failed. One or more differences found.
设置忽略AUTO_INCREMENT再进行差异比对,比对通过
mysqldiff--server1=root@localhost--server2=root@localhost--changes-for=server2--skip-table-options--difftype=sql testa.tba:testb.tbb;
# server1 on localhost:... connected.
# server2 on localhost:... connected.
# Comparing testa.tba to testb.tbb [PASS]
# Success. All objects are the same.
关于mysql数据库对比和mysql如何比对两个数据库表结构的方法的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。