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

简介: Technorati 标签: 在PL/SQL中创建表之前判断表是否存在 如果有就删除表的执行语句的书写  由于才开始使用PL/SQL来进行Oracle的客户端操作,由于以前使用sql 2005 来执行“创...

  由于才开始使用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语句做了一次包裹,才会避开编译检查。

相关文章
|
15天前
|
SQL 缓存 监控
大厂面试高频:4 大性能优化策略(数据库、SQL、JVM等)
本文详细解析了数据库、缓存、异步处理和Web性能优化四大策略,系统性能优化必知必备,大厂面试高频。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
大厂面试高频:4 大性能优化策略(数据库、SQL、JVM等)
|
1天前
|
SQL 数据库
gbase 8a 数据库 SQL优化案例-关联顺序优化
gbase 8a 数据库 SQL优化案例-关联顺序优化
|
15天前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第8天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括系统准备、配置安装源、安装 SQL Server 软件包、运行安装程序、初始化数据库以及配置远程连接。通过这些步骤,您可以顺利地在 CentOS 系统上部署和使用 SQL Server 2019。
|
16天前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第7天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括系统要求检查与准备、配置安装源、安装 SQL Server 2019、配置 SQL Server 以及数据库初始化(可选)。通过这些步骤,你可以成功安装并初步配置 SQL Server 2019,进行简单的数据库操作。
|
26天前
|
SQL Oracle 关系型数据库
Oracle数据库优化方法
【10月更文挑战第25天】Oracle数据库优化方法
34 7
|
26天前
|
SQL 数据采集 监控
局域网监控电脑屏幕软件:PL/SQL 实现的数据库关联监控
在当今网络环境中,基于PL/SQL的局域网监控系统对于企业和机构的信息安全至关重要。该系统包括屏幕数据采集、数据处理与分析、数据库关联与存储三个核心模块,能够提供全面而准确的监控信息,帮助管理者有效监督局域网内的电脑使用情况。
18 2
|
Oracle 关系型数据库
Oracle操作总结
聚合函数: count sum max min avg count返回的结果集中行的数目 sum max min avg顾名思义。但是要注意聚合函数强调的是"结果集中……",强调了 现在进行的操作对象是结果集 注意NULL不参与聚合函数的预算,要想其参加运算那么要将其转换为非空的值 分组: 在一个查询中需要进行多次统计就需要就必须使用分组 where是分组前过滤,过滤的是原始数据。
843 0
|
2月前
|
存储 Oracle 关系型数据库
Oracle数据库的应用场景有哪些?
【10月更文挑战第15天】Oracle数据库的应用场景有哪些?
173 64
|
26天前
|
Oracle 关系型数据库 数据库
oracle数据库技巧
【10月更文挑战第25天】oracle数据库技巧
26 6
|
26天前
|
存储 Oracle 关系型数据库
Oracle数据库优化策略
【10月更文挑战第25天】Oracle数据库优化策略
21 5

推荐镜像

更多
下一篇
无影云桌面