您的位置:首页 > 数据库 > Oracle

Oracle下的IF EXISTS()

2015-06-28 01:36 295 查看
妈蛋。。作为一个使用了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)两个语句块之间要用/来分开这样才可以执行
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: