在开发及调试的过程中,需要比对新旧代码的差异,我们可以使用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.
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
问题内容: 按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实,参考或专业知识的支持,但是这个问题可能会引起辩论,争论,民意调查或扩展讨论。如果您认为此问题可以解决并且可以重新提出,请访问帮助中心以获取指导。 7年前关闭。 已锁定 。该问题及其答案被锁定,因为该问题是题外话,但具有历史意义。它目前不接受新的答案或互动。 我目前正在使用MySQL数据库开发应用程序。 数据库结构仍在不
本文向大家介绍Mysql复制表结构、表数据的方法,包括了Mysql复制表结构、表数据的方法的使用技巧和注意事项,需要的朋友参考一下 本文给大家分享了好几种复制表结构、表数据的示例介绍,具体详情请看下文吧。 1、复制表结构及数据到新表 CREATE TABLE 新表SELECT * FROM 旧表 这种方法会将oldtable中所有的内容都拷贝过来,当然我们可以用delete from newtab
大家好,我正在学习如何使用MySQL和Node JS,我正在尝试找到一个混合两个表的查询。如果我得到一个表“users”,其中有列“userid”、“userimage”,另一个表“comments”,其中有列“commentID”、“comment”、“commentuserid”、“threadid”。你知道我是否可以添加用户的图片谁评论在这个查询的结果请?
我想创建一个食谱网站,在那里你可以添加/修改/删除食谱,每个模型都应该有一个配料的列表,与所需的量的那个配料。 我试图使用这样的dict:,但结果是EF Core并不真正喜欢dicts的思想,所以我试图创建一个“映射器”模型,如下所示: 问题是,它仍然没有真正起作用。我不能添加菜谱,也不能删除,因为它进入了一个永远循环。 你将如何实施它? 谢谢
问题内容: 从MySQL控制台,什么命令显示任何给定表的模式? 问题答案: 用于格式化输出,或 用于可用于创建表的SQL语句。
问题内容: 使用Linux,我想比较两个具有相同架构的SQLite数据库。只会有一些差异。 有没有可以输出这些差异的工具?最好将它们输出到命令行,以便我可以grep / sed它们。 SQLite使用SQL,因此一般的SQL工具也可以使用。 问题答案: 请查看2015年5月7日发布的SQLite版本3.8.10。此版本首次包含 sqldiff.exe 实用程序, 用于计算两个SQLite数据库文件