Oracle中复制表的方法(create as select、insert into select、select into)
转:
Oracle中复制表的方法(create as select、insert into select、select into)
(作者:陈玓玏)
在使用SQL的过程中,常常需要复制表,或者通过建立临时表来存储select语句生成的结果,这个在建模过程中造变量的时候用得尤其多。
1、用create as select
drop table tablename;
create table tablename as
select * from tab1;
- 1
- 2
- 3
Oracle中删除表格不能先用if exists做判断,所以如果表格不存在,直接运行这两句是会报错的。
关于这种方法的缺点:
一说是在其他博客看到的,意思是这种方法不能把默认值一起复制过来,这个错误在进行表备份时可能会有较大影响,但是对于做挖掘的朋友们来说,应该不怎么会影响我们造变量。而且Oracle很智能,即使你没有设定新表的字段类型,表的字段还是会根据你的原始字段或者分析函数的计算结果来存储。
二说这种方法的缺点是容易造成临时表空间不足。这种方法其实不是所有的数据库都会发生的,我碰到这种情况主要是因为数据库里写了很多触发器,每次drop table后再create table就会触发一次,而堡垒机上的数据库又常常反应不过来,就导致很多表已经删掉了,数据库以为还存在,结果可能就建不了表了。
正是因为这个缺点,我现在已经投向了insert into select的怀抱。
2、insert into select
truncate table tablename;
insert into tablename
select * from tab1;
commit;
- 1
- 2
- 3
- 4
这种方法其实是通过truncate一行一行地清空数据,再通过insert into一行一行地写入的。你会发现用create as复制表,会提示你执行完成,而用insert into,软件会提示你成功插入多少多少行记录。
再者,为什么要加commit? 如果不加commit,你会发现你的确能在Oracle中取到数据,但是如果你想用Python连接SQL来取数,会取到一个空表。所以如果你在Oracle中用了insert into来更新表的内容,请记得加commit,养成好习惯。
这种方法虽然保证我不会因为频繁叨扰触发器而碰到问题,但是也有以下几个缺点:
一是这种方法只能向已经存在的表中插入数据,所以如果表不存在,还是得先用create as;
二是这种方法只能插入相同字段的数据,也就是说如果你想新增或者删除字段,还是得用drop create as从头再来。
所以我喜欢在调试阶段用这种方法,因为总是避免不了造变量时候出点幺蛾子,要反复去修改取数逻辑,重跑数据表,一上来就频繁用create as,总觉得怪怪的。
3、select into
SELECT *
INTO tablename_backup
FROM tablename
- 1
- 2
- 3
这种方法显而易见了,就是为复制表而存在,备份表时可用,但是造变量时怕还是用上面两种更方便了。
Oracle中复制表的方法(create as select、insert into select、select into)的更多相关文章
- oracle中复制表和数据 && 多表插入语句
创建测试表和测试数据 create table test (id number,name varchar(10)); insert into test values(1,'liufang'); ...
- 如何在Oracle中复制表结构和表数据
1. 复制表结构及其数据: create table table_name_new as select * from table_name_old 2. 只复制表结构: create table ta ...
- Oracle中复制表结构和表数据
一.复制表结构及其数据 create table new_table as (select * from old_table); 二.只复制表结构 create table new_table as ...
- 如何在Oracle中复制表结构和表数据 【转载】
1. 复制表结构及其数据: create table table_name_new as select * from table_name_old 2. 只复制表结构: create table ta ...
- 【转载】如何在Oracle中复制表结构和表数据
1. 复制表结构及其数据: create table table_name_new as select * from table_name_old 2. 只复制表结构: create table ta ...
- 【转】如何在Oracle中复制表结构和表数据
特别提示:本人博客部分有参考网络其他博客,但均是本人亲手编写过并验证通过.如发现博客有错误,请及时提出以免误导其他人,谢谢!欢迎转载,但记得标明文章出处:http://www.cnblogs.com/ ...
- Oracle和sql server中复制表结构和表数据的sql语句
在Oracle和sql server中,如何从一个已知的旧表,来复制新生成一个新的表,如果要复制旧表结构和表数据,对应的sql语句该如何写呢?刚好阿堂这两天用到了,就顺便把它收集汇总一下,供朋友们参考 ...
- select XXX into 和 Insert into XXX select
检索一个表中的部分行存到另一张表中. 一 .另外的那张表没有新建的时候,使用 select XXX into,创建的表与原表有相同的列名和类型: select * into Departments_C ...
- oracle和mssql中复制表的比较
库内数据复制MS SQL Server: Insert into 复制表名称 select 语句 (复制表已经存在)select 字段列表 into 复制表名称 from 表 (复制表不存在) Ora ...
随机推荐
- JDK源码那些事儿之DelayQueue
作为阻塞队列的一员,DelayQueue(延迟队列)由于其特殊含义而使用在特定的场景之中,主要在于Delay这个词上,那么其内部是如何实现的呢?今天一起通过DelayQueue的源码来看一看其是如何完 ...
- Machine learning system design---prioritizing what to work on
prioritizing what to work on 设计一个机器学习算法时,我们应该先做什么?以垃圾邮件识别的例子为例: 垃圾邮件发送者可能会故意将一些字符写错,如上图中的Medicine用1 ...
- 用Visio画流程图
一:基本流程图 主要用于创建流程图.顺序图.信息跟踪图.流程规划图和结构预测图,包含了形状.连接线和链接. 步骤: (1)打开Visio,单击"类别"->"流程图& ...
- python是什么编程语言。
python是一门动态解释性的强类型定义语言.
- 0.0.Pycharm使用技巧
调整自动字体大小 Increase(字体变大) Decrease(字体变小) 背景颜色设置 pycharm 左侧菜单问题 解决 pycharm中配置启动Django项目 1.先打开mange.py,然 ...
- 转发大神nginx配置详解
序言 Nginx是lgor Sysoev为俄罗斯访问量第二的rambler.ru站点设计开发的.从2004年发布至今,凭借开源的力量,已经接近成熟与完善. Nginx功能丰富,可作为HTTP服务器,也 ...
- 从零开始开发一个Spring Boot Starter
一.Spring Boot Starter简介 Starter是Spring Boot中的一个非常重要的概念,Starter相当于模块,它能将模块所需的依赖整合起来并对模块内的Bean根据环境( 条件 ...
- C# 调用 C++ Dll 类型转换的方式 全
摘要:C#引用C++ Dll 所有类型转换的方式 //C++中的DLL函数原型为 //extern "C" __declspec(dllexport ...
- Oracle NVL 函数 nvl nvl2
Oracle中函数以前介绍的字符串处理,日期函数,数学函数,以及转换函数等等,还有一类函数是通用函数.主要有:NVL,NVL2,NULLIF,COALESCE,这几个函数用在各个类型上都可以. 下面简 ...
- Greenplum FTS故障检测原理
前言 FTS(Fault Tolerance Serve)是GreenPlum中的故障检测服务,是保证GP高可用的核心功能.GreenPlum的Segment的健康检测及HA是由GP Master实现 ...