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)两个语句块之间要用/来分开这样才可以执行

posted @ 2015-06-28 01:36  Jerry_Chen  阅读(5211)  评论(0编辑  收藏  举报