加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

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

发布时间:2020-12-12 06:23:35 所属栏目:MsSql教程 来源:网络整理
导读:我正在尝试创建一个SQL脚本(在SQL Server Management Studio中)以获取两个不同数据库中的所有表的列表.目标是找出两个数据库中存在哪些表,哪些表仅存在于其中一个. 我在SO上找到了各种脚本来列出一个数据库的所有表,但到目前为止,我无法获取多个数据库的表的
我正在尝试创建一个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以仅查看数据库之间的差异.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读