Подтвердить что ты не робот

Запрос SQL для поиска Первичного ключа таблицы?

Как я могу найти, какой столбец является основным ключом таблицы, используя запрос?

4b9b3361

Ответ 1

Для Oracle вы можете найти его в таблице ALL_CONSTRAINTS:

SELECT a.COLUMN_NAME
FROM all_cons_columns a INNER JOIN all_constraints c 
     ON a.constraint_name = c.constraint_name 
WHERE c.table_name = 'TBL'
  AND c.constraint_type = 'P';

DEMO.

Для SQL Server уже был дан ответ здесь, а для MySQL проверьте @ajon answer.

Ответ 2

Это дубликат question:

кредит Лукмдо за этот ответ:

Это может быть не рекомендуется, но работает нормально:

show index from TABLE where Key_name = 'PRIMARY' ;

Простым способом является использование information_schema:

SELECT k.COLUMN_NAME
FROM information_schema.table_constraints t
LEFT JOIN information_schema.key_column_usage k
USING(constraint_name,table_schema,table_name)
WHERE t.constraint_type='PRIMARY KEY'
    AND t.table_schema=DATABASE()
    AND t.table_name='owalog';

Ответ 3

Попробуйте этот запрос на SQL-сервере:

SELECT     X.NAME AS INDEXNAME,
           COL_NAME(IC.OBJECT_ID,IC.COLUMN_ID) AS COLUMNNAME
FROM       SYS.INDEXES  X 
INNER JOIN SYS.INDEX_COLUMNS  IC 
        ON X.OBJECT_ID = IC.OBJECT_ID
       AND X.INDEX_ID = IC.INDEX_ID
WHERE      X.IS_PRIMARY_KEY = 1
  AND      OBJECT_NAME(IC.OBJECT_ID)='YOUR_TABLE'

Ответ 4

Для MySQL:

SELECT GROUP_CONCAT(COLUMN_NAME), TABLE_NAME
FROM INFORMATION_SCHEMA.KEY_COLUMN_USAGE
WHERE
  TABLE_SCHEMA = '**database name**'
  AND CONSTRAINT_NAME='PRIMARY'
GROUP BY TABLE_NAME;

Предупреждение первичный ключ с двумя столбцами будет разделять их на кому (,)

Ответ 5

Следующий запрос предоставляет список всех первичных ключей в данной базе данных.

SELECT DISTINCT TABLE_NAME ,column_name
    FROM INFORMATION_SCHEMA.key_column_usage
    WHERE TABLE_SCHEMA IN ('*your_db_name*');