zoukankan      html  css  js  c++  java
  • MySQL 对比数据库的表结构

    有时候,需要对比一下测试环境和生产环境中,数据库的表结构是否有所差异。有两个常用的工具。

    AmpNmp.DatabaseCompare

    GUI 界面,支持多种数据库(MySQL、SQL Server、SQLite)简单高效,推荐。

    官方下载地址及文档
    百度网盘下载地址

    界面

    mysqldiff

    官方文档
    官方下载地址

    下载安装

    mysqldiff 是命令行工具,其优点是可以直接根据差异生成 SQL 语句。

    一般直接在本地开发环境安装,如果是 Windows 环境,需要提前安装 Visual C++ Redistributable Packages for Visual Studio 2013

    语法

    mysqldiff --server1=user:pass@host:port:socket --server2=user:pass@host:port:socket db1.object1:db2.object1 db3:db4

    mysqldiff 可以对比两个数据库,或只对比表:

    • db1:db2:如果只是指定数据库,那么就将两个数据库中互相缺少的对象显示出来,而对象里面的差异不进行对比;包括表、存储过程、函数、触发器等。
    • db1.object1:db2.object1:如果指定了具体表对象,那么就会详细对比两个表的差异,包括表名、字段名、备注、索引、大小写等都有的表相关的对象。

    参数:

    • --server1:配置server1的连接
    • --character-set:配置连接时用的字符集,如果不显示配置默认使用“character_set_client”
    • --width:配置显示的宽度
    • --skip-table-options:这个选项的意思是保持表的选项不变,即对比的差异里面不包括表名、AUTO_INCREMENT,ENGINE, CHARSET等差异。
    • -d DIFFTYPE,--difftype:差异的信息显示的方式,有[unified|context|differ|sql](default: unified),如果使用sql那么就直接生成差异的SQL这样非常方便。
    • --changes-for=:例如–changes-for=server2,那么对比以sever1为主,生成的差异的修改也是针对server2的对象的修改。
    • --show-reverse:这个字面意思是显示相反的意思,其实是生成的差异修改里面同时会包含server2和server1的修改。
  • 相关阅读:
    Redis数据库
    python的web运用
    python对 if __name__=='__main__'的理解
    python的函数
    python的四种内置数据结构
    python的循环和选择
    关于oracle设置主键自增的问题
    用HttpClient和用HttpURLConnection做爬虫发现爬取的代码少了的问题
    ORACLE not available如何解决
    集合(下)
  • 原文地址:https://www.cnblogs.com/kika/p/10851555.html
Copyright © 2011-2022 走看看