`
jiaoronggui
  • 浏览: 1303147 次
  • 性别: Icon_minigender_1
  • 来自: 合肥
博客专栏
B7c2eb31-a8ea-3973-a517-d00141f39b89
项目管理软件-redmin...
浏览量:115232
4a63e153-250f-30f6-a051-97cfc67cb3d3
IT职业规划
浏览量:197677
社区版块
存档分类
最新评论

慎用create table as select,一定要注意默认值的问题

阅读更多

再做一些数据迁移时候,很多人会使用create table  as select * from table where id=-1的方式来年建立一摸一样的表,但是这样做有个很大的弊端,不能将原表中的default value也一同迁移过来,可以看下面的例子:

 

第一,新建一个表

 

-- Create table
create table table01
(
  id        number(16),
  add_date  date default sysdate,
  status    number(1),
  entp_code varchar2(200)
)

 

第二,使用create table table02 as
select * From table01 where id=-1

 

第三、看看两个表的结构,会发现第二张表的defaule value没有了,如下2图,可以很明显看出来,表02的add_date的默认值得sysdate没有了

table01的表结构

 table02的表结构


 

所以各位在做数据库迁移时候,使用create table as select时候,一定要注意默认值的问题

 

上周,因为此问题,导致生产环境下产生了大量的问题,头大了一天,特此奉献出来。

  • 大小: 4.1 KB
  • 大小: 4 KB
0
3
分享到:
评论
1 楼 zllwang 2011-08-01  
是啊,也发现了

相关推荐

Global site tag (gtag.js) - Google Analytics