Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/sql-server/22.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Sql server 比较两个数据库中的索引_Sql Server_Tsql_Sql Server 2012 - Fatal编程技术网

Sql server 比较两个数据库中的索引

Sql server 比较两个数据库中的索引,sql-server,tsql,sql-server-2012,Sql Server,Tsql,Sql Server 2012,在更新客户的软件和数据库时,我们将他们的数据库与我们的开发数据库进行比较,以确保没有表丢失,并且所有表看起来都相同 由于存储在[DB].information\u Schema.Columns中的信息,执行此操作很容易 现在,我们想将客户机数据库中的所有索引与开发数据库进行比较,但我不知道在哪里进行比较。那么,我从哪里开始寻找呢 编辑: 我喜欢TSQL解决方案,而不是使用更多的软件来完成这项工作。是的,我知道RedGate有一些很棒的解决方案,但我不愿意为我可以免费做的事情付钱。这个问题不仅是

在更新客户的软件和数据库时,我们将他们的数据库与我们的开发数据库进行比较,以确保没有表丢失,并且所有表看起来都相同

由于存储在
[DB].information\u Schema.Columns
中的信息,执行此操作很容易

现在,我们想将客户机数据库中的所有索引与开发数据库进行比较,但我不知道在哪里进行比较。那么,我从哪里开始寻找呢

编辑:


我喜欢TSQL解决方案,而不是使用更多的软件来完成这项工作。是的,我知道RedGate有一些很棒的解决方案,但我不愿意为我可以免费做的事情付钱。这个问题不仅是为了完成工作,而且是为了获得更多关于SQL Server和学习的知识。

我会从一个比较工具开始,比如Microsoft SSDT(free-),或者Redgate的SQL Compare,而不是手动进行


或者,您可以查看系统索引

,我将从一个比较工具开始,比如Microsoft SSDT(免费-)或Redgate的SQL比较,而不是手动执行此操作


或者,您可以查看
sysindexes

,您可以使用此免费实用程序进行尝试

有时,我们在大型数据库上会遇到一些问题,但在其他情况下,它会解决问题


希望它能对你有所帮助,你可以试试这个免费工具

有时,我们在大型数据库上会遇到一些问题,但在其他情况下,它会解决问题


希望它能有所帮助

在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
我编写的脚本使用上面的查询,可以帮助比较两个数据库中的索引。

Compalex是一个轻量级脚本,用于比较两个数据库模式。信息技术 支持MySQL、MS SQL Server和PostgreSQL

屏幕截图(比较键):


在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
我编写的脚本使用上面的查询,可以帮助比较两个数据库中的索引。

Compalex是一个轻量级脚本,用于比较两个数据库模式。信息技术 支持MySQL、MS SQL Server和PostgreSQL

屏幕截图(比较键):


系统索引很棒!谢谢如果可以的话(3分钟内),我会接受答案。系统索引很棒!谢谢我会在可能的时候(3分钟内)接受答案。