jenrrychen

妈蛋。。作为一个使用了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)两个语句块之间要用/来分开这样才可以执行

分类:

技术点:

相关文章: