微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

sql-server – 如何获取两个不同数据库中的所有表的列表

我正在尝试创建一个sql脚本(在sql Server Management Studio中)以获取两个不同数据库中的所有表的列表.目标是找出两个数据库中存在哪些表,哪些表仅存在于其中一个.

我在SO上找到了各种脚本来列出一个数据库的所有表,但到目前为止,我无法获取多个数据库的表的列表.

那么,有没有办法来查询sql Server中特定数据库中的所有表,例如SELECT * FROM … WHERE databaseName =’first_db’,以便我可以将其与另一个数据库的结果相加?

解决方法

SELECT * FROM database1.informatION_SCHEMA.TABLES
UNION ALL
SELECT * FROM database2.informatION_SCHEMA.TABLES

UPDATE

为了比较这两个列表,您可以使用FULL OUTER JOIN,它将显示两个数据库中存在的表以及仅存在于其中一个的表:

SELECT *
FROM database1.informatION_SCHEMA.TABLES db1
  FULL JOIN database2.informatION_SCHEMA.TABLES db2
    ON db1.TABLE_NAME = db2.TABLE_NAME
ORDER BY COALESCE(db1.TABLE_NAME,db2.TABLE_NAME)

您还可以添加WHERE db1.TABLE_NAME IS NULL或db2.TABLE_NAME IS NULL以仅查看数据库间的差异.

原文地址:https://www.jb51.cc/mssql/79149.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐