Re: Имя unique key
- From
- Sergei Andreev (2:5020/400)
- To
- Alexander Cherepukhin
- Date
- 2005-10-18T17:23:38Z
- Area
- SU.DBMS.SQL
From: "Sergei Andreev" <S.Andreev@classicbank.com.ua>
> Как в MS-SQL запросом к системным таблицам определить
> существование и имя UNIQUE KEY-констрейнта (индекса)
> для заданной колонки заданной таблицы?
> Для PRIMARY KEY научился: sysindexes.indid=1,
Странно, а мне всегда казалось, что это всего-лишь кластерный индекс
> а вот UK...
Для констрейнта (однозначно):
SELECT Obj.[Name]
FROM SysConstraints Cnst
JOIN SysObjects Tbl
ON (Cnst.[Status] & 2) <> 0 -- Уникальный ключ (1 - Первичный ключ)
AND
Tbl.[Id] = Cnst.[Id]
AND
Tbl.[XType] = 'U' -- Пользовательская таблица
AND
Tbl.[Name] = 'TableName' -- Имя таблицы
JOIN SysColumns Col
ON Tbl.[Id] = Col.[Id]
AND
Col.[ColId] = Cnst.[ColId]
AND
Col.[Name] = 'ColumnName' -- Имя колонки
JOIN SysObjects Obj
ON Obj.[Id] = Cnst.[ConstId]
Для индекса (очень вероятно):
SELECT Ind.[Name]
FROM SysIndexes Ind
JOIN SysIndexKeys Keys
ON Keys.[Id] = Ind.[Id]
AND
Keys.[IndId] = Ind.[IndId]
JOIN SysObjects Obj
ON (Ind.[Status] & 2) <> 0 -- Уникальный индекс
AND
Obj.[Id] = Ind.[Id]
AND
Obj.[XType] = 'U' -- Пользовательская таблица
AND
Obj.[Name] = 'TableName' -- Имя таблицы
JOIN SysColumns Col
ON Col.[Id] = Obj.[Id]
AND
Col.[ColId] = Keys.[ColId]
AND
Col.[Name] = 'ColumnName' -- Имя колонки
--- ifmail v.2.15dev5.3
* Origin: ClassicBank, Ltd (2:5020/400)
SEEN-BY: 46/50 50/12 203 520 450/159 186 1024 451/30 454/9 461/43 132 640
SEEN-BY: 469/999 4614/20 4616/3 4625/8 4627/10 4641/444 5000/76 5000 5001/5001
SEEN-BY: 5006/1 5007/1 5010/53 70 5011/13 5012/23 46 5015/10 28 5019/31
SEEN-BY: 5020/86 118 175 194 400 545 604 639 715 758 830 892 982 1042 1057
SEEN-BY: 5020/1200 1523 1604 1665 1909 1922 2013 2020 2238 4441 5021/3 29
SEEN-BY: 5022/128 5025/3 750 5026/10 14 45 5027/16 5029/32 5030/115 217 436
SEEN-BY: 5030/473 556 966 1063 1339 1900 5035/38 5036/1 34 5040/47 5042/13
SEEN-BY: 5045/7 5047/43 47 5049/1 5051/15 5053/16 5054/1 8 9 28 35 37 45 63 67
SEEN-BY: 5055/95 5057/1 5059/9 5060/88 5061/15 5062/1 5066/18 5069/7 5070/1222
SEEN-BY: 5077/70 5080/68 1003 5081/2 5082/6 5083/21 5084/32 5085/13 5090/106
SEEN-BY: 5093/27 5095/20 5099/133 6000/12 254 6009/1
PATH: 5020/400 4441 545 5054/1 37