首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >【DB笔试面试675】在Oracle中,如何快速复制表或插入数据?

【DB笔试面试675】在Oracle中,如何快速复制表或插入数据?

作者头像
AiDBA宝典
发布2019-11-05 15:23:14
发布2019-11-05 15:23:14
1.5K00
代码可运行
举报
运行总次数:0
代码可运行

题目部分

在Oracle中,如何快速复制表或插入数据?

答案部分

快速复制表可以指定NOLOGGING选项,如:

代码语言:javascript
代码运行次数:0
运行
复制
CREATE TABLE T1 NOLOGGING AS SELECT * FROM T2;

快速插入数据可以指定APPEND提示,需要注意的是,在NOARCHIVELOG模式下,默认用了APPEND就是NOLOGGING模式的。在ARCHIVELOG下,需要把表设置程NOLOGGING模式。如:

代码语言:javascript
代码运行次数:0
运行
复制
INSERT /*+ APPEND */ INTO T1   SELECT * FROM T2;

注意:若在环境中设置了FORCE LOGGING,则以上操作是无效的,并不会加快插入的速度,当然,可以通过如下语句设置为NO FORCE LOGGING。

代码语言:javascript
代码运行次数:0
运行
复制
ALTER DATABASE NO FORCE LOGGING;

是否开启了FORCE LOGGING,可以用如下语句查看:

代码语言:javascript
代码运行次数:0
运行
复制
SQL> SELECT FORCE_LOGGING FROM V$DATABASE;

本文选自《Oracle程序员面试笔试宝典》,作者:小麦苗

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-11-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 DB宝 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档