zoukankan      html  css  js  c++  java
  • 数据库检查约束是否存在

    http://stackoverflow.com/questions/2499332/how-to-check-if-a-constraint-exists-in-sql-server

    Easiest way to check for the existence of a constraint (and then do something such as drop it if it exists) is to use the OBJECT_ID() function...

    IF OBJECT_ID('dbo.[CK_ConstraintName]', 'C') IS NOT NULL 
        ALTER TABLE dbo.[tablename] DROP CONSTRAINT CK_ConstraintName

    OBJECT_ID can be used without the second parameter ('C' for check constraints only) and that may also work, but if your constraint name matches the name of other objects in the database you may get unexpected results.

    IF OBJECT_ID('dbo.[CK_ConstraintName]') IS NOT NULL 
        ALTER TABLE dbo.[tablename] DROP CONSTRAINT CK_ConstraintName

    OBJECT_ID can also be used with other "constraints" such as Foreign Key constraints or Primary Key constraints, etc. For best results, always include the appropriate object type as the second parameter for the OBJECT_ID function:

    Constraint Object Types:

    • C = CHECK constraint
    • D = DEFAULT (constraint or stand-alone)
    • F = FOREIGN KEY constraint
    • PK = PRIMARY KEY constraint
    • R = Rule (old-style, stand-alone)
    • UQ = UNIQUE constraint

    Also note that the schema is often required. The schema of constraints generally takes the schema of the parent table.

    Failure to put your constraints (or whatever you are checking) in brackets when using this method may also cause a false negative -- if your object uses unusual characters (such as a .), the brackets are required.

  • 相关阅读:
    STM32的串口DMA收发以及双缓冲区的实现
    平衡二叉树
    二叉树的深度
    3D数学基础(四)四元数和欧拉角
    3D数学基础(三)矩阵
    3D数学基础(二)向量
    3D数学基础(一)Unity坐标系
    快速学会开发微信小程序
    苦逼的程序员
    开通博客,在这个年末,重新开始。
  • 原文地址:https://www.cnblogs.com/wucg/p/6186377.html
Copyright © 2011-2022 走看看