zoukankan      html  css  js  c++  java
  • sql server 查找主键、外键、索引、约束

    主键约束

    SELECT
      tab.name AS [表名],
      idx.name AS [主键名称],
      col.name AS [主键列名]
    FROM
      sys.indexes idx
        JOIN sys.index_columns idxCol
          ON (idx.object_id = idxCol.object_id
              AND idx.index_id = idxCol.index_id
              AND idx.is_primary_key = 1)
        JOIN sys.tables tab
          ON (idx.object_id = tab.object_id)
        JOIN sys.columns col
          ON (idx.object_id = col.object_id
              AND idxCol.column_id = col.column_id);
     
    唯一约束
    SELECT
      tab.name AS [表名],
      idx.name AS [约束名称],
      col.name AS [约束列名]
    FROM
      sys.indexes idx
        JOIN sys.index_columns idxCol
          ON (idx.object_id = idxCol.object_id
              AND idx.index_id = idxCol.index_id
              AND idx.is_unique_constraint = 1)
        JOIN sys.tables tab
          ON (idx.object_id = tab.object_id)
        JOIN sys.columns col
          ON (idx.object_id = col.object_id
              AND idxCol.column_id = col.column_id);
     
    外键约束
    select
      oSub.name  AS  [子表名称],
      fk.name AS  [外键名称],
      SubCol.name AS [子表列名],
      oMain.name  AS  [主表名称],
      MainCol.name AS [主表列名]
    from
      sys.foreign_keys fk 
        JOIN sys.all_objects oSub 
            ON (fk.parent_object_id = oSub.object_id)
        JOIN sys.all_objects oMain
            ON (fk.referenced_object_id = oMain.object_id)
        JOIN sys.foreign_key_columns fkCols
            ON (fk.object_id = fkCols.constraint_object_id)
        JOIN sys.columns SubCol
            ON (oSub.object_id = SubCol.object_id 
                AND fkCols.parent_column_id = SubCol.column_id)
        JOIN sys.columns MainCol
            ON (oMain.object_id = MainCol.object_id 
                AND fkCols.referenced_column_id = MainCol.column_id)
     
    Check约束
    SELECT
      tab.name AS [表名],
      chk.name AS [Check约束名],
      col.name AS [列名],
      chk.definition
    FROM
      sys.check_constraints chk
        JOIN sys.tables tab
          ON (chk.parent_object_id = tab.object_id)
        JOIN sys.columns col
          ON (chk.parent_object_id = col.object_id
              AND chk.parent_column_id = col.column_id)
  • 相关阅读:
    接口自动化1-基础知识
    pytest-fixture之conftest.py
    测试人员一定要懂的ADB操作,赶紧来看一看~
    必看!利用装饰器,帮你自动处理异常并优雅实现重跑case
    最全Airtest接口功能介绍和示例总结,新手同学千万不能错过呀!(二)
    总结一波 Redis 面试题,收藏起来!
    IntelliJ IDEA 2020.2.4款 神级超级牛逼插件推荐
    华为 Java 开发编程军规,谁违反谁走
    CTO:再写if-else,逮着罚款1000!
    VSCode 上竟然也能约会,谈对象了???
  • 原文地址:https://www.cnblogs.com/colder/p/3259813.html
Copyright © 2011-2022 走看看