在线精品99_中国九九盗摄偷拍偷看_91免费版在线观看_91.app_91高清视频在线_99热最新网站

Oracle中怎么利用联机重定义给表增加新列与分区

137次阅读
没有评论

共计 5442 个字符,预计需要花费 14 分钟才能阅读完成。

本篇文章给大家分享的是有关 Oracle 中怎么利用联机重定义给表增加新列与分区,丸趣 TV 小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着丸趣 TV 小编一起来看看吧。

1. 用要执行联机重定义操作的用户登录数据库

SQL  conn pm/pm@jypdb Connected.

2. 验证表 emp_redef 是否可以执行联机重定义。在这种情况下,可以使用主键或伪主键来来进行验证。

SQL  exec dbms_redefinition.can_redef_table(uname= HR ,tname= EMP_REDEF ,options_flag= dbms_redefinition.cons_use_pk); PL/SQL procedure successfully completed.

3. 创建一个中间表 hr.int_emp_redef

SQL  create table hr.int_emp_redef ( employee_id NUMBER(6) not null, first_name VARCHAR2(20), last_name VARCHAR2(25) not null, job_id VARCHAR2(10) not null, department_id NUMBER(4) not null, mgr NUMBER(5), hiredate DATE DEFAULT(sysdate), sal NUMBER(7,2), bonus NUMBER(7,2) DEFAULT(0) ) partition by range(employee_id) ( partition emp200 values less than(200) tablespace users, partition emp400 values less than(400) tablespace users ); Table created

4. 开始重定义操作

SQL  begin dbms_redefinition.start_redef_table( uname =   hr , orig_table =   emp_redef , int_table =   int_emp_redef , col_mapping =   employee_id employee_id, first_name first_name,last_name last_name, job_id job_id, department_id+10 department_id,0 bonus , options_flag =  DBMS_REDEFINITION.CONS_USE_PK); end; / PL/SQL procedure successfully completed.

5. 复制依赖对象 (自动对表 hr.int_emp_redef 创建任何触发器,索引,物化视图日志,授权与约束)

SQL  declare num_errors pls_integer; begin dbms_redefinition.copy_table_dependents( uname =   hr , orig_table =   emp_redef , int_table =   int_emp_redef , copy_indexes =  DBMS_REDEFINITION.CONS_ORIG_PARAMS, copy_triggers =  TRUE, copy_constraints =  TRUE, copy_privileges =  TRUE, ignore_errors =  TRUE, num_errors =  num_errors); end; / PL/SQL procedure successfully completed.

注意,在调用这个过程时 ignore_errors 参数需要设置为 TRUE。原因是中间表创建了主键约束,并且当执行 copye_table_dependents 过程来试图从原始表复制主键约束与索引时会发生错误。可以忽略这些错误,但必须执行下一步操作中的查询来查看是否还存在其它错误。

6. 查询 dba_redefinition_errors 视图来查看错误信息

SQL  set long 8000 SQL  set pages 8000 SQL  column object_name heading  object name  format a20 SQL  column base_table_name heading  base table name  format a10 SQL  column ddl_txt heading  ddl that caused error  format a40 SQL  select object_name, base_table_name, ddl_txt from dba_redefinition_errors; object name base table ddl that caused error -------------------- ---------- ---------------------------------------- SYS_C0023200 EMP_REDEF ALTER TABLE  HR . INT_EMP_REDEF  MODIFY (LAST_NAME  CONSTRAINT  TMP$$_SYS_C0023 2000  NOT NULL ENABLE NOVALIDATE) SYS_C0023201 EMP_REDEF ALTER TABLE  HR . INT_EMP_REDEF  MODIFY (JOB_ID  CONSTRAINT  TMP$$_SYS_C0023201 0  NOT NULL ENABLE NOVALIDATE) 2 rows selected.

上面的错误信息是说中间表的 last_name 与 job_id 列为 not null,而原因表为 null,这种错误可以忽略。

7. 同步中间表 hr.int_emp_redef

SQL  begin dbms_redefinition.sync_interim_table( uname =   hr , orig_table =   emp_redef , int_table =   int_emp_redef  end; / PL/SQL procedure successfully completed.

8. 完成重定义操作

SQL  begin dbms_redefinition.finish_redef_table( uname =   hr , orig_table =   emp_redef , int_table =   int_emp_redef  end; / PL/SQL procedure successfully completed.

表 hr.emp_redef 只会以排他模式被锁定很短的时间来结束重定义操作。在操作完成后,表 hr.emp_redef 将使用 hr.int_emp_redef 表的所有属性来重定义。

SQL  desc hr.emp_redef Name Type Nullable Default Comments ------------- ------------ -------- --------- -------- EMPLOYEE_ID NUMBER(6) FIRST_NAME VARCHAR2(20) Y LAST_NAME VARCHAR2(25) JOB_ID VARCHAR2(10) DEPARTMENT_ID NUMBER(4) MGR NUMBER(5) Y HIREDATE DATE Y (sysdate) SAL NUMBER(7,2) Y BONUS NUMBER(7,2) Y (0) SQL  select dbms_metadata.get_ddl(object_type = TABLE ,name = EMP_REDEF ,schema =   HR) from dual; DBMS_METADATA.GET_DDL(OBJECT_TYPE= TABLE ,NAME= EMP_REDEF ,SCHEMA= HR) -------------------------------------------------------------------------------- CREATE TABLE  HR . EMP_REDEF  (  EMPLOYEE_ID  NUMBER(6,0) NOT NULL ENABLE,  FIRST_NAME  VARCHAR2(20),  LAST_NAME  VARCHAR2(25) NOT NULL ENABLE,  JOB_ID  VARCHAR2(10) NOT NULL ENABLE,  DEPARTMENT_ID  NUMBER(4,0) NOT NULL ENABLE,  MGR  NUMBER(5,0),  HIREDATE  DATE DEFAULT (sysdate),  SAL  NUMBER(7,2),  BONUS  NUMBER(7,2) DEFAULT (0), CONSTRAINT  EMP_REDEF_EMP_ID_PK  PRIMARY KEY (EMPLOYEE_ID) USING INDEX PCTFREE 10 INITRANS 2 MAXTRANS 255 COMPUTE STATISTICS STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE  USERS  ENABLE ) PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 STORAGE( BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE  USERS  PARTITION BY RANGE (EMPLOYEE_ID) (PARTITION  EMP200  VALUES LESS THAN (200) SEGMENT CREATION IMMEDIATE PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 NOCOMPRESS LOGGING STORAGE(INITIAL 8388608 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE  USERS  , PARTITION  EMP400  VALUES LESS THAN (400) SEGMENT CREATION IMMEDIATE PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 NOCOMPRESS LOGGING STORAGE(INITIAL 8388608 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645 PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE  USERS  )
row selected.

可以看到表 hr.emp_redef 已经成功能联机重定义

9. 等任何查询中间表的语句执行完成后将其删除,而且中间表在重定义后其结构就变成了原始表的表结构

SQL  desc hr.int_emp_redef Name Type Nullable Default Comments ------------- ------------ -------- ------- -------- EMPLOYEE_ID NUMBER(6) Y FIRST_NAME VARCHAR2(20) Y LAST_NAME VARCHAR2(25) JOB_ID VARCHAR2(10) DEPARTMENT_ID NUMBER(4) Y SQL  drop table hr.int_emp_redef purge; Table dropped

以上就是 Oracle 中怎么利用联机重定义给表增加新列与分区,丸趣 TV 小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注丸趣 TV 行业资讯频道。

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-08-03发表,共计5442字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: 四虎影视永久费观看在线 | 亚洲精品无码久久 | 天码av无码一区二区三区四区 | 在线观看精品国产福利片100 | 国产精品久久久久久小说 | 成人免费一区二区三区视频软件 | 精品伊人久久久大香线蕉天堂 | 久久精品国产半推半就 | 国产日韩精品欧美一区色 | 欧美aa视频 | 亚洲高清综合 | 免费99视频有精品视频高清 | 欧美精品一卡二卡 | 亚洲在线免费 | 国产精品自产拍高潮在线观看 | 成人片黄网站a毛片免费 | 丰满少妇在线观看网站 | 免费无码av一区二区三区 | 全免费a敌肛交毛片免费 | 99re九精品视频在线视频 | 国产chinesehd精品酒店 | 久久精品岛国av一区二区无码 | 曰本女人牲交高潮视频 | 亚洲中文字幕无码中字 | 国产百合互慰吃奶互揉视频 | 小蜜被两老头吸奶头 | 国内精品乱码卡一卡2卡麻豆 | 福利视频在线播放 | 瑟瑟久久 | 黄色片网站日本 | 精品久久视频 | 人人妻人人澡人人爽 | 久久人人爽人人爽人人片av不 | 熟妇高潮精品一区二区三区 | 色妺妺在线视频 | 国模大胆一区二区三区 | 亚洲日韩精品欧美一区二区 | 男人的天堂comwww | 国产aⅴ精品一区二区三区久久 | 精品欧美成人bd高清在线观看 | 日本三级欧美三级人妇视频黑白配 |