oracle(PL/SQL)表操作:创建表时检查数据库是否存在该表,若存在删除再创建

转载 2012年03月27日 15:07:37

  由于才开始使用PL/SQL来进行Oracle的客户端操作,由于以前使用sql 2005 来执行“创建表之前判断表是否存在 如果有就删除表,再创建”的操作语句非常简单:

1:  if exists (
2:  select * from sysobjects 
3:  where id = OBJECT_ID('STUDENTS]') and OBJECTPROPERTY(id, 'IsUserTable') = 1) 
4:  DROP TABLE [STUDENTS]

然而令我非常郁闷的是,用同样的方法在PL/SQL里却不能运行,提示编译错误。

后来去网上查了相关的帖子之后自己写了如下方法实现:

 1:  declare 
 2:    cnt number;
 3:  begin
 4:    ---查询要创建的表是否存在
 5:    select count(*)into cnt from user_tables where table_name='STUDENTS'; 
 6:    
 7:    ---如果存在则删除该表
 8:    if cnt>0 then
 9:     execute immediate 'drop table STUDENTS';
10:     dbms_output.put_line('表存在,删除成功!');
11:    end if;
12:    ---删除之后再创建该表
13:    execute immediate 'CREATE TABLE STUDENTS
14:      ( 
15:      SNO NUMERIC(6, 0) NOT NULL,
16:      SNAME CHAR (8) NOT NULL ,
17:      AGE  NUMERIC(3,0) ,
18:      SEX  CHAR(2) ,
19:      BPLACE CHAR(20) ,
20:      PRIMARY KEY(SNO) 
21:      )
22:      tablespace Users' ;
23:  end; 

对比之后,大家不难发现,PL/SQL是把sql语句做了一次包裹,才会避开编译检查。

相关文章推荐

之前创建了一个表空间,然后今天不小心把表空间文件给删除了。然后用pl/sql连接数据库的时候,报ORA-01033错误。ora-01033:oracle initializationg or shut

之前创建了一个表空间,然后今天不小心把表空间文件给删除了。然后用pl/sql连接数据库的时候,报ORA-01033错误。ora-01033:oracle initializationg or shut...

Oracle PL/SQL开发基础(第十一弹:表集合操作)

在Oracle中,可供使用的集合运算有: - 联合运算:从两个查询返回的结果集去掉重复值后合并后的结果,使用UNION操作符。 - 全联合运算:与联合运算相似,返回两个查询结果的并集,但是包括所有...

创建触发器报PL/SQL: ORA-00942: 表或视图不存在

SQL> create user u1 identified by u1; 用户已创建。 SQL> grant dba to prod; 授权成功。 SQL> grant dba to u1;...

Oracle定时删除、增加表分区(TOAD,PL/SQL)

转自:http://blog.csdn.net/imasmallbird/archive/2008/11/20/3340547.aspx 今日完成了这个任务,特做总结   首先,建立分区表。...

恢复oracle中用pl/sql误删除drop掉的表

查看回收站中表 select object_name,original_name,partition_name,type,ts_name,createtime,droptime from recyc...

Oracle数据库操作大全(十三)——pl/sql编程(存储过程、函数、触发器)

1.存储过程、函数、触发器局

oracle数据库入门pl/sql基本操作

sql 语句的基本操作 1.create CREATE TABLE tablename( id number not null primary key, name varchar(...

Oracle数据库操作大全(十四)pl/sql编程之存储过程

存储过程:

使用PL/SQL Developer工具来实现创建表空间、创建数据库、备份数据库、数据导出等操作

如何结合Sql脚本和PL/SQL Developer工具来实现创建表空间、创建数据库、备份数据库、数据导出等操作,然后实现Oracle对象创建、导入数据等操作,方便我们快速了解、创建所需要的部署Sql...

oracle数据库操作,安装 pl/sql操作

  • 2009年12月15日 17:01
  • 1.42MB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:oracle(PL/SQL)表操作:创建表时检查数据库是否存在该表,若存在删除再创建
举报原因:
原因补充:

(最多只允许输入30个字)