Я пытаюсь заменить коллегу в работе с Oracle, и натолкнулся на загадку. Пытаясь написать скрипт для изменения столбца, чтобы он мог обнуляться, я столкнулся с прекрасной ошибкой ORA-01451:
ORA-01451: column to be modified to NULL cannot be modified to NULL
Это происходит потому, что столбец уже равен NULL. У нас есть несколько баз данных, которые необходимо обновить, поэтому в своем ошибочном предположении я решил, что установка его в NULL должна работать по всем направлениям, чтобы убедиться, что все были в курсе, независимо от того, установили ли они этот столбец вручную в NULL или нет. Тем не менее, это, очевидно, вызывает ошибку у некоторых людей, которые уже имеют столбец как обнуляемый.
Как проверить, является ли столбец уже обнуляемым, чтобы избежать ошибки? Что-то, что могло бы реализовать эту идею:
IF( MyTable.MyColumn IS NOT NULLABLE)
ALTER TABLE MyTable MODIFY(MyColumn NULL);