oracle中创建表时先判断是否存在表再drop的SQL

oracle中创建表时先判断是否存在表再drop的SQL

在写oracle的创建表的SQL时,为了SQL能够反复执行,一般都会在create前面加入drop表的语句,但这样先drop再create的语句在第一次执行时,会报一个不存在该表的错误,查了一下,oracle中没有像sybase那样先判断是否存在表再drop表的语句。

    sybase中用以下语句就能轻松判断是否已经存在了某表:

if exists (select 1             from  sysobjects             where  id = object_id('user_info')             and    type = 'U')    drop table user_info go

或者

if object_id('xxx_view')is not null    drop view xxx_view go

    第一种方式中其中type为对象的类型,如果对象是view,刚type='V'

     而oracle中,并没有这样方便的语句,然而我们难道就不能实现这个功能了吗?

     可以利用存储过程来实现,例如以下语句:

declare num number; begin select count(1) into num from user_tables where table_name='user_info'; if num>0 then execute immediate 'drop table user_info'; end if; execute immediate 'create table user_info (user_code varchar2(10) not null,  user_name varchar2(30), sex    varchar2(1), constraint pk_user_info primary key (user_code))'; end; /

    不过将这样的存储过程与正常的sql放在一起执行时,一定要加最后一行的“/”,以告诉编译器存储过程执行完毕,可以继续执行正常的SQL了,我就犯过这样的错误。


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值