在更新客户的软件和数据库时,我们将他们的数据库与我们的开发数据库进行比较,以确保没有表缺失,并且所有表看起来都相同。
由于存储在[DB].Information_Schema.Columns
。
现在,我们要将客户端数据库中的所有索引与开发数据库进行比较,但我不知道在哪里进行比较。那么,我从哪里开始寻找?
修改
我会喜欢TSQL解决方案而不是获得更多软件来完成这项工作。是的,我知道RedGate有一些很好的解决方案,但我不愿意为我能免费提供的东西买单。这个问题不仅仅是为了完成工作,而是为了获得更多关于SQL Server和学习的知识。
答案 0 :(得分:2)
我会从像Microsoft SSDT(免费 - http://msdn.microsoft.com/en-us/data/tools.aspx)或Redgate的SQL Compare这样的比较工具开始,而不是手动执行此操作。
或者,您可以查看sysindexes
答案 1 :(得分:2)
在Microsoft SQL Server数据库中显示索引的脚本是:
USE [database name];
SELECT
t.name tableName,
ind.name indexName,
col.name columnName,
key_ordinal columnOrder
FROM
sys.indexes ind
INNER JOIN
sys.index_columns ic ON ind.object_id = ic.object_id and ind.index_id = ic.index_id
INNER JOIN
sys.columns col ON ic.object_id = col.object_id and ic.column_id = col.column_id
INNER JOIN
sys.tables t ON ind.object_id = t.object_id
WHERE
ind.is_primary_key = 0
AND ind.is_unique = 0
AND ind.is_unique_constraint = 0
AND t.is_ms_shipped = 0
ORDER BY
t.name, ind.name, ind.index_id, ic.index_column_id
我编写使用上述查询的脚本,可以帮助比较两个数据库中的索引。 https://github.com/dlevsha/compalex
Compalex是一个用于比较两个数据库模式的轻量级脚本。它 支持MySQL,MS SQL Server和PostgreSQL。
屏幕截图(比较键):
答案 2 :(得分:1)