MySQL只有在存在的情况下才会删除外键约束

时间:2013-11-07 00:47:49

标签: mysql foreign-keys

现在已经找了差不多一个小时了,我简直不敢相信我还没弄明白怎么做。我发现了这个:

Drop constraints only if it exists in mysql server 5.0

但是那里提供的链接没有足够的信息让我在那里..有人可以提供代码示例吗?

更新

很抱歉,我在原始问题中并不清楚,但我希望有一种方法可以在SQL中执行此操作,而不是使用任何应用程序编程。

1 个答案:

答案 0 :(得分:2)

示例php代码:

function removeFK(PDO $pdo, $dbName, fkName)
{
    echo "Removing foreign key '$fkName' from database: $dbName\t";

    $exists = $pdo->query("
        SELECT TRUE
        FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS
        WHERE CONSTRAINT_TYPE = 'FOREIGN KEY'
            AND TABLE_SCHEMA = '$dbName'
            AND CONSTRAINT_NAME = '$fkName'
        ")->fetchColumn();

    if ($exists === false) {
        echo " [SKIPPING] (FK does not exist)\n";
        return false;
    }

    $pdo->query("USE $dbName");
    $pdo->query("
        ALTER TABLE intelligence_webpage_has_region_keyword
        DROP FOREIGN KEY $fkName");

    echo "[OK]\n";
    return true;
}