Oracle下的IF EXISTS()

妈蛋。。作为一个使用了SQL SERVER有4 5年的程序猿,开始用Oracle真他妈不习惯。写法真他妈不一样。比如像写个像IF EXISTS(SELECT * FROM sys.tables WHERE name = 'xxxx') BEGIN DROP TABLE XXXX END这样的语句,发现在ORACLE下完全两码事。妹的。。于是百度啊。最后发现

1)Oracle下没有IF EXISTS(),Oracle下要实现IF EXISTS()要这么写

declare 
      num   number; 
begin 
      select count(1) into num from all_tables where TABLE_NAME = 'TEST2'; 
      if   num=1   then 
          execute immediate 'drop table TEST2'; 
      end   if; 
end; 

需要用个变量去存all_tables输出的结果,然后再判断
2)SQL SERVER下的IF .... BEGIN ... END到了Oracle下变成了IF .... THEN ... END IF;而且每一句都要加个;  这个好像还是必须的

3)两个语句块之间要用/来分开这样才可以执行

转载于:https://www.cnblogs.com/jenrrychen/p/4605008.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值