DECLARE
      CURSOR tab_name_cur
      IS
          SELECT table_name
          FROM user_tables
          WHERE table_name LIKE 'GZD_GZDXX_%_2017';   
      tab_name_rec         tab_name_cur%ROWTYPE ;
      SQL_Str_Create       VARCHAR2(2500);
      SQL_Str_Comments     VARCHAR2(2500);
      SQL_Str_Pk           VARCHAR2(2500);
      Pk_column_name    user_cons_columns.column_name%TYPE;
      SQL_Str_default      VARCHAR2(2500);
    
BEGIN
      OPEN tab_name_cur;
      LOOP
       FETCH tab_name_cur INTO tab_name_rec;
       EXIT
            WHEN tab_name_cur%NOTFOUND;
               --dbms_output.put_line(tab_name_rec.table_name);
           --复制表
           SQL_Str_Create := ' CREATE TABLE ' || SUBSTR(tab_name_rec.table_name,1,LENGTH(tab_name_rec.table_name)-5)
                           || '_2018' || ' AS SELECT * FROM ' || tab_name_rec.table_name || ' WHERE 1=2' || ';' ;
           dbms_output.put_line(SQL_Str_Create);
           --execute IMMEDIATE SQL_Str_Create;
           --查询主键
        SELECT string_agg(cu.column_name) as  column_name INTO Pk_column_name
                    FROM user_cons_columns cu, user_constraints au
                    WHERE cu.constraint_name = au.constraint_name
                    AND au.constraint_type = 'P'
                    AND au.table_name = tab_name_rec.table_name
                    GROUP BY cu.constraint_name;
            
         --dbms_output.put_line('pk_column_name :' || tab_pk_rec.column_name || ' and constraint_name :' ||                 tab_pk_rec.constraint_name);
                   
         dbms_output.put_line('Pk_column_name--> '||Pk_column_name);   
                 
               
            --增加主键
            SQL_Str_Pk := 'alter table ' || tab_name_rec.table_name || ' add constraint '  
                                  ||' PK_'||tab_name_rec.table_name || ' primary key('
                                  ||  Pk_column_name
                                  ||') using index tablespace USERS pctfree 10 initrans 2 '
                                  || ' maxtrans 255  storage ('
                                  || 'initial 64K next 1M minextents 1 maxextents unlimited );';
             dbms_output.put_line(SQL_Str_Pk);     
           --查询备注
           FOR tab_commonts_rec IN
               (SELECT column_name,comments
               FROM user_col_comments c
               WHERE c.table_name = tab_name_rec.table_name)
               LOOP
                   --dbms_output.put_line('column_name :' || tab_commonts_rec.column_name || ' and                        comments :' ||tab_commonts_rec.comments);
                --增加备注
                   SQL_Str_Comments := 'comment on column ' || tab_name_rec.table_name
                                       || '.' || tab_commonts_rec.column_name               
                                       || ' IS '  || chr(39)||tab_commonts_rec.comments ||chr(39)||  ';' ;
                dbms_output.put_line(SQL_Str_Comments);
            END LOOP;
           
           --查询默认值
           FOR tab_commonts_default IN
               (SELECT t.column_name as column_name,t.data_type as data_type
            FROM USER_TAB_COLS t
            WHERE TABLE_NAME =tab_name_rec.table_name)
            LOOP
                   CASE tab_commonts_default.data_type
                       WHEN 'NUMBER' THEN
                           --dbms_output.put_line(tab_commonts_default.column_name || ' is NUMBER');
                           --增加默认值
                           SQL_Str_default := 'alter table '||tab_name_rec.table_name||' modify '
                                               || tab_commonts_default.column_name || ' default 0;';
                          dbms_output.put_line(SQL_Str_default);
                       WHEN 'VARCHAR2' THEN
                           --dbms_output.put_line(tab_commonts_default.column_name || ' is VARCHAR2');
                           SQL_Str_default := 'alter table '||tab_name_rec.table_name||' modify '
                                               || tab_commonts_default.column_name || ' default NULL;';
                          --dbms_output.put_line(SQL_Str_default);
                       ELSE
                         dbms_output.put_line(tab_commonts_default.column_name || ' is Unknown');
                   END CASE;
            END LOOP;            
      END LOOP;
      CLOSE  tab_name_cur;          
END;

亲测截图:

执行结果如下图:

大批量复制Oracle数据表,连带复制主键约束,字段说明以及字段默认值(量产)的更多相关文章

  1. 【数据库_Mysql】MySQL—修改表时给表添加联合主键约束

      添加语法如下: “ALTER TABLE table_name ADD CONSTRAINT pk_table_name PRIMARY KEY(列名1,列名2):” [示例1]假设订房信息表(O ...

  2. oracle建表 和 设置主键自增

    1.新建table CREATE TABLE ysb_log( id ) primary key not null , tbdate ) NULL, tb_time ) NOT NULL, tblog ...

  3. Oracle创建表(包含、主键自增)

    注意:Oracle导出建表语句不会导出触发器及自增索引 第一步:创建一张表 create table member( memberId number primary key, --主键.自增长 mem ...

  4. 更新oracle数据库表如何实现主键自增长

     在数据库中实现主键自动增长有利于我们做数据插入操作,在SQL SERVER上创建表时可以在int类型的字段后加上identity(1,1),该字段就会从1开始,按照+1的方式自增,将这个字段设置 ...

  5. 数据表设计之主键自增、UUID或联合主键

    最近在做数据库设计的时候(以MySQL为主),遇到不少困惑,因为之前做数据库表设计,基本上主键都是使用自增的形式,最近因为这种做法,被领导指出存在一些不足,于是我想搞明白哪里不足. 一.MySQL为什 ...

  6. Oracle 创建表并设置主键自增

    创建数据库 CREATE TABLE STUDENT(ID NUMBER PRIMARY KEY, NAME VARCHAR(200) NOT NULL, SEX VARCHAR(200), CREA ...

  7. oracle建表,设置主键,修改属性等

    --建表 create table book( book_id number(10), book_name varchar2(20), book_price number(10,2), book_au ...

  8. 【Oracle】【5】主键、外键管理

    前言: 1,事实上我是不使用外键的,所以本文只介绍主键 正文: (1)创建表的同时创建主键约束 create table STUDENT ( ID int , NAME varchar(8), AGE ...

  9. SQL约束(主键约束、外键约束、自动递增、不允许空值、值唯一、值默认、值限制范围)

    NOT NULL 不允许空值约束 NOT NULL 约束强制列不接受 NULL 值(NULL值就是没有值或缺值).NOT NULL 约束强制字段始终包含值,即不向字段添加值,就无法插入新记录或者更新记 ...

随机推荐

  1. Mysql跨数据库(在同一IP地址中)复制表

    数据库表间数据复制分类 在利用数据库开发时,常常会将一些表之间的数据互相导入.当然可以编写程序实现,但是,程序常常需要开发环境,不方便.最方便是利用sql语言直接导入.既方便而修改也简单.以下就是导入 ...

  2. HDU 1226 超级密码(数学 bfs)

    传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1226 超级密码 Time Limit: 20000/10000 MS (Java/Others)    ...

  3. android 网络技术基础学习 (七)

    使用httpclient协议访问网络: public class MainActivity extends Activity implements OnClickListener{ public vo ...

  4. Linux服务器SMB服务挂载目录

    挂载方法 mount -o username=账号,password=密码 //SMB服务器IP/共享目录 /挂载点 smbclient链接 smbclient //SMB服务器IP/共享目录/ -U ...

  5. Java实现批量修改文件名,重命名

    平时下载的文件.视频很多都会有网址前缀,比如一些编程的教学视频,被人共享出来后,所有视频都加上一串长长的网址,看到就烦,所以一般会重命名后看,舒服很多,好了,不多说,直接上代码: 以下代码演示使用递归 ...

  6. ETO的公开赛T3《寻星》 题解(BY 超級·考場WA怪 )

    题解 寻星 题意:给定一个有向带权图,定义从一点到另一点的某条路径长为路径上所有边权的最大值,并给定四个点编号w,t1,t2,t3. 求出一个点s,使它在到t1,t2,t3三点最短路径最大值最大或者根 ...

  7. 【TOJ 3692】紧急援救

    #include<iostream> #include<algorithm> #include<queue> using namespace std; #defin ...

  8. solr索引大小对比

    原文本 Solr建立的索引 如果进行Mysql索引应该是1:3的比例

  9. 路由器基础配置之广播多路访问链路上的ospf

    我们将以上面的拓扑图进行实验,因为是要以不断广播的形式进行ospf,所有中间加了一个集线器,这种ospf和前一种不同,路由器之间会在配置好ospf之后选举出一个老大,DR,一个备份,BDR,而其他路由 ...

  10. 一道SQL面试题——表行列数据转换(表转置)

    SQL语句如下: select country, sum(case when type='A' then money end) as A, sum(case when type='B' then mo ...