暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

Oracle 从现有表复制表

askTom 2017-02-24
140

问题描述

嗨,




您将如何通过省略特定的列名将表从现有表复制到新表。
如果列很少,我们可以指定列名,但是它的表很大,并且有很多列。

专家解答

你不能通过否定来指定列,即,你不能做这样的事情:

选择 “* 除col1”

您需要指定所有列,但是您可以轻松编写脚本,例如

SQL> create table t as select * from dba_objects;

Table created.

SQL> desc t
 Name                                                                    Null?    Type
 ----------------------------------------------------------------------- -------- ------------------------------------------------
 OWNER                                                                            VARCHAR2(128)
 OBJECT_NAME                                                                      VARCHAR2(128)
 SUBOBJECT_NAME                                                                   VARCHAR2(128)
 OBJECT_ID                                                                        NUMBER
 DATA_OBJECT_ID                                                                   NUMBER
 OBJECT_TYPE                                                                      VARCHAR2(23)
 CREATED                                                                          DATE
 LAST_DDL_TIME                                                                    DATE
 TIMESTAMP                                                                        VARCHAR2(19)
 STATUS                                                                           VARCHAR2(7)
 TEMPORARY                                                                        VARCHAR2(1)
 GENERATED                                                                        VARCHAR2(1)
 SECONDARY                                                                        VARCHAR2(1)
 NAMESPACE                                                                        NUMBER
 EDITION_NAME                                                                     VARCHAR2(128)
 SHARING                                                                          VARCHAR2(13)
 EDITIONABLE                                                                      VARCHAR2(1)
 ORACLE_MAINTAINED                                                                VARCHAR2(1)

SQL>
SQL> select listagg(column_name,',') within group ( order by column_id)
  2  from user_tab_columns
  3  where table_name = 'T'
  4  and column_name not in ('OWNER','CREATED');

LISTAGG(COLUMN_NAME,',')WITHINGROUP(ORDERBYCOLUMN_ID)
----------------------------------------------------------------------------------------------------------------------------------
OBJECT_NAME,SUBOBJECT_NAME,OBJECT_ID,DATA_OBJECT_ID,OBJECT_TYPE,LAST_DDL_TIME,TIMESTAMP,STATUS,TEMPORARY,GENERATED,SECONDARY,NAMES
PACE,EDITION_NAME,SHARING,EDITIONABLE,ORACLE_MAINTAINED


「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论