`
tylgl
  • 浏览: 56835 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

快速复制一张大表讨论

SQL 
阅读更多
有这样的一类需求,快速复制一张表,而这张表的数据量又非常的大。比方说本来是分区表,要把它重新变成非分区表,怎么能够快速的完成这样的操作呢?我下面给出2种大致的方法:

第一,就是利用CTAS方式来创建一张新表,当然要想加快速度,在数据库不是force logging的前提下,可以使用nologging方式来创建表

SQL> create table auction_auctions_bak
  2  tablespace tbs_taobao
  3  nologging
  4  as
  5  select * from auction_auctions;

Table created.

SQL> select count(*) from auction_auctions;

  COUNT(*)
----------
   4179779

SQL> select count(*) from auction_auctions_bak;

  COUNT(*)
----------
   4179779
在建立完成表以后,要注意将表的属性重新变成logging:

SQL> select logging from tabs where table_name='AUCTION_AUCTIONS_BAK';

LOG
---
NO

SQL> alter table auction_auctions_bak logging;

Table altered.
当然也可以这样:CREATE TABLE … AS SELECT .. WHERE 1=2;然后使用 INSERT /*+ APPEND */ INTO .. SELECT …。

最后将表名更改过来,建立一下新的索引,然后就可以了。

SQL> drop table auction_auctions;

Table dropped.

SQL> rename auction_auctions_bak to auction_auctions;

Table renamed.
第二,在原理上,它其实和第一种方式差不多,就是阻止数据库记录日志来加快速度,大概过程如下:

1、exp出原表(建议compress=n)
2、drop 原表
3、以nologging的方式,新建与原表同名的空表
4、imp原表至空表中,注意要把ignore设置为y
5、更改新表的属性为logging

我这次分别都对两种方式做了测试,结果第二种方式远远快于第一种方式,大概是其10倍的速度。注意以上两种方式都是在数据库没有force logging的前提下完成的。如果数据库被force logging了,那么怎样才能加快复制速度,这个大家可以说说。
分享到:
评论

相关推荐

    怎么最快地复制一张表?.pdf

    在数据库管理中,快速复制一张表的内容是一项常见的任务,尤其在数据迁移、备份或测试环境中。本文将探讨两种常用的方法,以高效地实现这一操作,它们分别是使用`mysqldump`命令和导出CSV文件。 首先,让我们详细...

    行业文档-设计装置-快速绘图纸制造方法.zip

    在现代工业设计与制造领域,快速绘图纸制造方法是一种至关重要的技术,它极大地提升了设计师们的工作效率和设计质量。这份“行业文档-设计装置-快速绘图纸制造方法”压缩包包含了一个名为“快速绘图纸制造方法.pdf”...

    合并多个Excel文件的方法 多个文件内容简单放到一个文件里

    如果我们手动复制和粘贴每个表,那么工作量将变得非常大。因此,需要找到一种快速和高效的方法来合并多个Excel文件。 那么,如何合并多个Excel文件呢?方法之一是使用Excel的“移动或复制工作表”功能。首先,打开...

    「酷哥说库」一张图看懂openGauss(第1期)- openGauss概述.docx

    同时,其高可用性体现在故障自动检测、快速故障切换、数据复制等功能,能够在系统出现异常时,确保服务的连续性和数据的一致性。 openGauss的可扩展性是其另一大亮点。通过水平扩展和垂直扩展策略,可以轻松应对...

    大型数据库Oracle脱机备份研究与应用.pdf

    然后,重新装载并打开数据库,对数据库进行操作,创建一张新表,插入一条记录。最后,使用之前已经拷贝的数据文件(.dbf 文件),实现数据库的恢复。该恢复以在mount状态下恢复为主。 此外,本文还介绍了移动支付...

    表情包(嘻哈猴全报请包)可以QQ/论坛使用,gif格式

    而论坛上,用户通常需要将gif表情上传到个人空间或者第三方图床,然后复制链接插入帖子,嘻哈猴表情包的大小和格式通常能满足这些平台的要求。 总的来说,嘻哈猴表情包以其嘻哈元素和gif动画形式,为网络交流提供了...

    Hadoop、HBase、Hive、Pig、Zookeeper资料整理

    3. **Hive**:Hive是构建在Hadoop上的数据仓库工具,可以将结构化的数据文件映射为一张数据库表,并提供SQL(HQL)似的查询语言进行数据查询、分析。Hive将SQL查询转换为MapReduce任务执行,简化了对Hadoop数据的...

    十八个常用的Powerpoint演示小技巧汇总.docx

    7. **快速复制格式**:选中具有特定格式的对象,如文本框或图片,按"Crtl+C"复制,然后选中新对象,按"Crtl+V"粘贴格式,无需重新设置样式。 8. **自定义动画和过渡效果**:在"动画"和"过渡"选项卡中,可以为每一页...

    Win8的11个细节.docx

    5. **升级的地址栏**:在Windows 8中,地址栏变得更加实用,用户可以直接将文件拖放到地址栏上的相应文件夹节点,实现快速移动或复制,尤其对于深度目录结构,这极大地简化了操作流程。 6. **混合启动**:Windows 8...

    ppt制作技术使用技巧

    4. **复制幻灯片**:快速复制幻灯片,可以先在“大纲”或“幻灯片”视图中选中目标幻灯片,然后使用“插入”菜单的“幻灯片副本”选项或使用快捷键Ctrl+Shift+D。 5. **快速切换屏幕状态**:在演示过程中,按"B"键...

    Powerpoint幻灯片技巧分享.docx

    可以在“大纲”或“幻灯片”视图中选择需要的幻灯片,按住Shift键进行连续选择,或按Ctrl键进行非连续选择,然后在“插入”菜单上点击“幻灯片副本”,或者直接使用快捷键Ctrl+Shift+D,即可快速复制幻灯片。...

    便捷高效截屏小工具

    今天我们要讨论的是一款名为"FSCapture"的高效截屏小工具,它专为Windows用户设计,以其便捷性和安全性深受用户喜爱。 FSCapture是一款轻量级的屏幕截图软件,无需安装,这意味着你可以直接运行程序,减少了系统...

    简单好用的截图、贴图工具:Snipaste

    - **复制/粘贴图像**:你可以将截图直接复制到剪贴板,然后在任何支持图像粘贴的地方(如Word、PPT、聊天软件等)使用。 - **保存与分享**:Snipaste允许快速保存截图至本地,支持多种格式(如JPEG、PNG),同时...

    重要知识PPT制作技术.pdf

    4. **复制幻灯片**:在“大纲”或“幻灯片”视图中,通过按住Shift或Ctrl键选择幻灯片,然后使用“插入”菜单中的“幻灯片副本”或使用快捷键Ctrl+Shift+D,可以快速复制幻灯片。 5. **快速切换屏幕模式**:在讲解...

    144项PPT制作技术.doc

    4. **复制幻灯片**:快速复制幻灯片,可以通过在“大纲”或“幻灯片”视图中选取需要复制的幻灯片,然后使用“插入”菜单的“幻灯片副本”功能,或者使用快捷键“Ctrl + Shift + D”,方便快捷。 5. **Powerpoint...

    PPT演示技巧

    在制作和展示PPT(PowerPoint)的过程中,掌握一些实用技巧能够极大地提升演示的效率和效果。以下是一些关键点: 1. **复制幻灯片**:在普通视图的“大纲”或“幻灯片”选项中选择需要复制的幻灯片,按住Shift键可...

    实用powerpoint技巧(DOC20页).doc

    解决方法是从任务窗格中打开“幻灯片切换”,将换片方式小节中的“单击鼠标时”和“每隔”两个复选项全部去除,然后将这个设置应用于所有幻灯片,以后切换到下一张或上一张,只有通过键盘上的方向键才能进行操作。...

    常用Powerpoint演示技巧汇总.docx

    如果是用复制粘贴来完成这一操作,实在有点麻烦,其实最快速的方法就是先选择多张幻灯片,接着按下alt+shift+s即可。 这项技巧可以帮助用户快速地生成内容简介,提高演示文稿的整体性和美观性。 六、快速定位幻灯...

    实用的ppt教程

    - 在“插入”菜单中点击“幻灯片副本”选项,或直接使用`Ctrl+Shift+D`组合键来实现快速复制。 - 被复制的幻灯片将被插入到当前位置之后。 #### 三、Powerpoint自动黑屏功能 - **应用场景**:当演示者需要观众...

Global site tag (gtag.js) - Google Analytics