2011-06-21 1 views
1

Есть ли способ найти связь между таблицами в базе данных с помощью запроса или графического интерфейса в SQL Express 2005?ms sql - найти реляционные таблицы в базе данных

Другое, а затем вручную ищет соответствующие первичные/внешние ключи в таблицах, есть ли более простой способ сделать это?

ответ

0

Я считаю, что скрипт, который вы ищете идет по следующей ссылке:

http://blog.sqlauthority.com/2006/11/01/sql-server-query-to-display-foreign-key-relationships-and-name-of-the-constraint-for-each-table-in-database/

Вот сценарий:

SELECT 
K_Table = FK.TABLE_NAME, 
FK_Column = CU.COLUMN_NAME, 
PK_Table = PK.TABLE_NAME, 
PK_Column = PT.COLUMN_NAME, 
Constraint_Name = C.CONSTRAINT_NAME 
FROM INFORMATION_SCHEMA.REFERENTIAL_CONSTRAINTS C 
INNER JOIN INFORMATION_SCHEMA.TABLE_CONSTRAINTS FK ON C.CONSTRAINT_NAME = FK.CONSTRAINT_NAME 
INNER JOIN INFORMATION_SCHEMA.TABLE_CONSTRAINTS PK ON C.UNIQUE_CONSTRAINT_NAME = PK.CONSTRAINT_NAME 
INNER JOIN INFORMATION_SCHEMA.KEY_COLUMN_USAGE CU ON C.CONSTRAINT_NAME = CU.CONSTRAINT_NAME 
INNER JOIN (
SELECT i1.TABLE_NAME, i2.COLUMN_NAME 
FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS i1 
INNER JOIN INFORMATION_SCHEMA.KEY_COLUMN_USAGE i2 ON i1.CONSTRAINT_NAME = i2.CONSTRAINT_NAME 
WHERE i1.CONSTRAINT_TYPE = 'PRIMARY KEY' 
) PT ON PT.TABLE_NAME = PK.TABLE_NAME 
---- optional: 
--ORDER BY 1,2,3,4 
--WHERE PK.TABLE_NAME='something'WHERE FK.TABLE_NAME='something' 
--WHERE PK.TABLE_NAME IN ('one_thing', 'another') 
--WHERE FK.TABLE_NAME IN ('one_thing', 'another') 

Обратите внимание, что вы можете добавить некоторые необязательные инструкции внизу, чтобы ограничить или заказать свои результаты. На выходе будет отображаться таблица, содержащая внешний ключ, имя поля, таблица первичного ключа и поле, на которое оно ссылается, и имя, которое было присвоено.

0

В SSMS щелкните правой кнопкой мыши на столе и выберите дизайн.

Существует кнопка, которая выглядит как 2 или 3 окна с линией между ними, это показывает отношения для этой таблицы.

enter image description here

Откроется окно ForeignKey, который будет показывать каждую связь между этой таблицей и любой другой таблицей это касается, он также покажет, какие поля соединить эти таблицы.

+0

Это отображает таблицы/представления/SP и т. Д., Но не имя строки. Нужно ли просто найти строку, которая зависит от основной таблицы? Или это невозможно? – tdjfdjdj

+0

Я не уверен, что я понимаю, вы хотите знать, что пользователи привязаны к учетным записям на Users.AccountId = Account.Id? Или вы хотите знать, что Пользователь 123 является частью учетной записи 456? – taylonr