MODIFY COLUMN в oracle - Как проверить, можно ли обнулять столбец, прежде чем устанавливать на nullable? - PullRequest
35 голосов
/ 22 июня 2009

Я пытаюсь заменить коллегу в работе с 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);

Ответы [ 2 ]

44 голосов
/ 22 июня 2009

Вы можете сделать это в PL / SQL:

declare
  l_nullable user_tab_columns.nullable%type;
begin
  select nullable into l_nullable
  from user_tab_columns
  where table_name = 'MYTABLE'
  and   column_name = 'MYCOLUMN';

  if l_nullable = 'N' then
    execute immediate 'alter table mytable modify (mycolumn null)';
  end if;
end;
21 голосов
/ 22 июня 2009

просто измените таблицу и поймайте исключение.

DECLARE
   allready_null EXCEPTION;
   PRAGMA EXCEPTION_INIT(allready_null, -1451);
BEGIN
   execute immediate 'ALTER TABLE TAB MODIFY(COL  NULL)';
EXCEPTION
   WHEN allready_null THEN
      null; -- handle the error
END;
/

, если вы не хотите использовать PL / SQL

    set feedback off
    set echo off
    set feedback off
    set pages 0
    set head off

    spool to_null.sql

    select 'alter table TAB modify (COL NULL);' 
    from user_tab_columns
    where table_name = 'TAB'
    and column_name = 'COL'
    and nullable = 'N';

    spool off
    set feedback on
    set echo on
    set termout on
    @@to_null.sql 
    host rm -f to_null.sql

или просто измените таблицу и проигнорируйте ошибку.

...