iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >mysql怎么对比两个数据库表结构
  • 886
分享到

mysql怎么对比两个数据库表结构

2024-04-02 19:04:59 886人浏览 泡泡鱼
摘要

这篇文章主要介绍了Mysql怎么对比两个数据库表结构,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。在开发及调试的过程中,需要对比新旧代码的差

这篇文章主要介绍了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怎么对比两个数据库表结构”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网数据库频道,更多相关知识等着你来学习!

您可能感兴趣的文档:

--结束END--

本文标题: mysql怎么对比两个数据库表结构

本文链接: https://www.lsjlt.com/news/54972.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • mysql怎么对比两个数据库表结构
    这篇文章主要介绍了mysql怎么对比两个数据库表结构,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。在开发及调试的过程中,需要对比新旧代码的差...
    99+
    2024-04-02
  • java实现mysql两个数据库对比表结构是否一致
    【使用场景】 本地开发完后,增加或者删除了字段,或者修改了字段属性。 如何判定现场环境和本地环境的数据表结构一致性? 肉眼看的话,实在是一个大的工作量,所以开发了此工具。 【类存放路径】 CompareDbMain是主函数。 【具体代码】...
    99+
    2023-09-11
    数据库 mysql
  • 草稿整理后mysql两个数据库结构对比
    目录1、草稿:2、整理:3、无注释总结1、草稿: -- 1.将mysql分隔符从;设置为& DELIMITER & -- 2.如果存在存储过程getdatabaseC...
    99+
    2024-04-02
  • oracle怎么对比两个表中数据差异
    要对比两个表中的数据差异,可以使用Oracle中的MINUS操作符或者使用JOIN操作来实现。以下是分别使用这两种方法进行数据差异对...
    99+
    2024-04-30
    oracle
  • MySQL数据库结构和引擎比对分析
    这篇文章主要介绍“MySQL数据库结构和引擎比对分析”,在日常操作中,相信很多人在MySQL数据库结构和引擎比对分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MySQL数据库结构和引擎比对分析”的疑惑有所...
    99+
    2023-06-02
  • 怎么修改mysql数据库表结构
    这篇文章主要介绍了怎么修改mysql数据库表结构,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。修改mysql数据库表结构的方法:1、查看表结构;...
    99+
    2024-04-02
  • mysql数据库中怎么导出表结构
    本篇文章给大家分享的是有关mysql数据库中怎么导出表结构,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。mysql表结构导出 命令行...
    99+
    2024-04-02
  • 结构化SQL数据库与非结构化NOSQL数据库的对比是怎样的
    今天就跟大家聊聊有关结构化SQL数据库与非结构化NOSQL数据库的对比是怎样的,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。大家好,我们来谈一下数据...
    99+
    2024-04-02
  • mysql怎么导出数据库所有表结构
    如果想要导出MySQL数据库中所有表的结构,可以使用以下命令: mysqldump -u username -p --no-data...
    99+
    2024-04-09
    mysql 数据库
  • oracle怎么比较两个表数据差异
    在Oracle数据库中,可以使用以下方法比较两个表之间的数据差异: 使用MINUS操作符:可以使用MINUS操作符来比较两个表之间...
    99+
    2024-04-09
    oracle
  • mysql中怎么导出单个表结构和数据
    今天就跟大家聊聊有关mysql中怎么导出单个表结构和数据,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。从mysql中导出单个表结构和数据 ...
    99+
    2024-04-02
  • 应该怎么样去对MySQL数据库的表结构进行修改
    这篇文章给大家分享的是有关应该怎么样去对MySQL数据库的表结构进行修改的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。MySQL ALTER TABLE语句ALTER ...
    99+
    2024-04-02
  • mysql怎么查看数据表结构
    在MySQL中,可以使用DESCRIBE语句来查看数据表的结构。语法如下:DESCRIBE table_name;其中,table_...
    99+
    2023-10-12
    mysql
  • mysql怎么导出数据库结构
    使用MySQL的mysqldump命令可以导出数据库的结构。 以下是导出数据库结构的步骤: 打开命令行终端或者命令提示符; 进入M...
    99+
    2024-04-09
    mysql 数据库
  • oracle怎么导出数据库表结构
    在Oracle数据库中,可以使用以下方法导出数据库表结构: 使用SQL Developer工具导出表结构:在SQL Develo...
    99+
    2024-04-09
    oracle 数据库
  • sqlserver怎么导出数据库表结构
    要导出SQL Server数据库表结构,可以使用SQL Server Management Studio (SSMS) 或者使用SQ...
    99+
    2024-04-09
    sqlserver 数据库
  • oracle数据库怎么备份表结构
    要备份 oracle 数据库表的结构,可以使用 create table 语句 همراه با explain 子句。具体步骤包括: 1. 打开 oracle sql*plus; 2....
    99+
    2024-04-18
    oracle
  • MySQL怎么查看数据库结构
    可以通过以下命令来查看MySQL数据库的结构: 使用SHOW命令查看数据库列表: SHOW DATABASES; 使用DES...
    99+
    2024-04-09
    mysql 数据库
  • plsql怎么导出数据库表结构
    在PL/SQL中,可以使用以下语句来导出数据库表的结构: SELECT dbms_metadata.get_ddl(...
    99+
    2024-04-09
    plsql 数据库
  • oracle怎么查看数据库表结构
    要查看Oracle数据库中表的结构,可以使用以下方法之一:1. 使用Oracle SQL Developer:Oracle SQL ...
    99+
    2023-08-23
    oracle 数据库
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作