首页 > 解决方案 > 使用单个语句更改多个表中的公共列

问题描述

因为我们可以在单个查询中更改表的多个列。

无论如何,我们可以在 Oracle 的单个语句中更改多个表的公共列吗?

标签: sqloraclealter

解决方案


不完全是一条语句,但是 - 如果您认为一段 PL/SQL 代码可能会有所帮助,这里有一个示例:有些表包含NAME具有不同VARCHAR2数据类型长度的列名。我要把它们统一VARCHAR2(10).

SQL> create table t1 (id number(4), name varchar2(5));

Table created.

SQL> create table t2 (id number(4), name varchar2(3));

Table created.

SQL> create table t3 (id number(4), name varchar2(8));

Table created.

SQL> begin
  2    for cur_r in (select table_name from user_tab_columns where column_name = 'NAME') loop
  3      execute immediate 'alter table ' || cur_r.table_name || ' modify name varchar2(10)';
  4    end loop;
  5  end;
  6  /

PL/SQL procedure successfully completed.

SQL> desc t1
 Name                                      Null?    Type
 ----------------------------------------- -------- ----------------------------
 ID                                                 NUMBER(4)
 NAME                                               VARCHAR2(10)

SQL> desc t2
 Name                                      Null?    Type
 ----------------------------------------- -------- ----------------------------
 ID                                                 NUMBER(4)
 NAME                                               VARCHAR2(10)

SQL> desc t3
 Name                                      Null?    Type
 ----------------------------------------- -------- ----------------------------
 ID                                                 NUMBER(4)
 NAME                                               VARCHAR2(10)

SQL>

或者,运行SELECT组成这些语句的语句ALTER TABLE,复制/粘贴并运行它们:

SQL> select 'alter table ' || table_name ||' modify name varchar2(20);' str
  2  from user_tab_columns
  3  where column_name = 'NAME';

STR
--------------------------------------------------------------------
alter table T1 modify name varchar2(20);    --> these 3 lines should be
alter table T2 modify name varchar2(20);    --  copy/pasted (as I did it below)
alter table T3 modify name varchar2(20);    --  and executed

SQL> alter table T1 modify name varchar2(20);

Table altered.

SQL> alter table T2 modify name varchar2(20);

Table altered.

SQL> alter table T3 modify name varchar2(20);

Table altered.

SQL> desc t1
 Name                                      Null?    Type
 ----------------------------------------- -------- ----------------------------
 ID                                                 NUMBER(4)
 NAME                                               VARCHAR2(20)

SQL> desc t2
 Name                                      Null?    Type
 ----------------------------------------- -------- ----------------------------
 ID                                                 NUMBER(4)
 NAME                                               VARCHAR2(20)

SQL> desc t3
 Name                                      Null?    Type
 ----------------------------------------- -------- ----------------------------
 ID                                                 NUMBER(4)
 NAME                                               VARCHAR2(20)

SQL>

推荐阅读