mysql - sql 找出2个数据库的差异表名
问题描述
同一个数据库,本地51张表和远程49张表,有差异数据表。如何通过一条SQL来快速找出这些表的名字。
SQL:
USE performance_schema;SELECT t1.OBJECT_SCHEMA,t1.OBJECT_NAME,t2.OBJECT_SCHEMA,t2.OBJECT_NAMEFROM `table_io_waits_summary_by_table` t1 RIGHT JOIN `table_io_waits_summary_by_table` t2 ON t1.OBJECT_NAME = t2.OBJECT_NAMEWHERE t1.OBJECT_SCHEMA=’db1_local’ AND t2.OBJECT_SCHEMA=’db2_remote’;
结果集只有49张,无法罗列出差异的表明。使用了 LEFT OUTER JOIN 还是一样。
验证是存在差异的:
SELECT OBJECT_NAMEFROM table_io_waits_summary_by_table WHERE OBJECT_SCHEMA=’db1_local’ AND OBJECT_NAME NOT IN (SELECT OBJECT_NAME FROM table_io_waits_summary_by_table WHERE OBJECT_SCHEMA=’db2_remote’ )
问题解答
回答1:试试这个:
USE performance_schema;SELECT t1.*FROM `table_io_waits_summary_by_table` t1 LEFT JOIN `table_io_waits_summary_by_table` t2 ON t1.OBJECT_NAME = t2.OBJECT_NAME AND t2.OBJECT_SCHEMA=’db2_remote’WHERE t1.OBJECT_SCHEMA=’db1_local’ AND t2.OBJECT_NAME IS NULL;
其实你的第一个SQL只要将对t2的限制提到连接条件中就行了,将t2.OBJECT_SCHEMA=’db2_remote’写在where条件里面RIGHT JOIN就变成了INNER JOIN ~
相关文章:
1. java - spring-data Jpa 不需要执行save 语句,Set字段就可以自动执行保存的方法?求解2. android - 安卓做前端,PHP做后台服务器 有什么需要注意的?3. python的bs4如何筛选出h1标签中的内容4. docker-compose 为何找不到配置文件?5. docker gitlab 如何git clone?6. angular.js - 通过数据中children的个数自动生成能点击展开的div7. javascript - 移动端H5页面禁止缩放了,在浏览器上仍然可以缩放8. css - 使用blur()滤镜为什么有透明的效果9. apache - 怎么给localhost后面默认加上8080端口10. javascript - Vue.js2.0不能使用debounce后大伙一般是如何解决延迟请求的问题的呢。
