我的编程空间,编程开发者的网络收藏夹
学习永远不晚

oracle自定义存储过程:删除表(无论表是否存在)和检测表是否存在

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

oracle自定义存储过程:删除表(无论表是否存在)和检测表是否存在

oracle删除表,如果表不存在,就报错,在跑大型脚本(脚本长且耗时的时候)比较麻烦,一般希望的是点开始然后脚本运行到结束,不可能一直盯着屏幕等弹出提示手工点掉,mysql就很好有drop table if not exist功能

CREATE OR REPLACE PROCEDURE p_drop_table_if_exist(p_vc2_tbl_name  IN all_tables.table_name%TYPE,
                                    p_vc2_tbl_owner IN all_tables.owner%TYPE DEFAULT USER) IS
    v_num_tbl_count NUMBER(4);
    v_vc2_sql_stmt  VARCHAR2(1000);
  BEGIN
    -- Check if table already exists
    p_chk_table_exist(p_vc2_tbl_name, p_vc2_tbl_owner, v_num_tbl_count);
    IF (v_num_tbl_count != 0) THEN
      -- Table already exists and must be dropped
      v_vc2_sql_stmt := "DROP TABLE " || CASE
                          WHEN p_vc2_tbl_owner IS NOT NULL THEN
                           p_vc2_tbl_owner || "."
                        END || p_vc2_tbl_name || " purge"
                        ;
      --dbms_output.put_line(v_vc2_sql_stmt);
      EXECUTE IMMEDIATE v_vc2_sql_stmt;
    END IF;
  END;




CREATE OR REPLACE PROCEDURE p_chk_table_exist(p_vc2_tbl_name  IN all_tables.table_name%TYPE,
                                p_vc2_tbl_owner IN all_tables.owner%TYPE DEFAULT USER,
                                p_num_tbl_count OUT NUMBER -- 1 if table exists, 0 if it doesn"t
                                ) IS
    v_vc2_tbl_name all_tables.table_name%TYPE := UPPER(p_vc2_tbl_name);
  BEGIN

    IF p_vc2_tbl_owner IS NOT NULL THEN
      SELECT COUNT(1)
        INTO p_num_tbl_count
        FROM all_tables
       WHERE table_name = v_vc2_tbl_name
         AND owner = UPPER(p_vc2_tbl_owner);
    ELSE
      SELECT COUNT(1)
        INTO p_num_tbl_count
        FROM user_tables
       WHERE table_name = v_vc2_tbl_name;
    END IF;
  END p_chk_table_exist;

have fun

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

oracle自定义存储过程:删除表(无论表是否存在)和检测表是否存在

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

oracle自定义存储过程:删除表(无论表是否存在)和检测表是否存在

oracle删除表,如果表不存在,就报错,在跑大型脚本(脚本长且耗时的时候)比较麻烦,一般希望的是点开始然后脚本运行到结束,不可能一直盯着屏幕等弹出提示手工点掉,mysql就很好有drop table if not exist功能CREATE OR REPLA
2020-01-13

Oracle存储过程示例:检测表是否存在

Oracle存储过程示例:检测表是否存在在Oracle数据库中,有时候我们需要编写存储过程来检测特定的表是否存在,以便在程序逻辑中做出相应的处理。本文将介绍如何编写一个Oracle存储过程来检测表是否存在,并提供具体的代码示例。首先,我
Oracle存储过程示例:检测表是否存在
2024-03-08

Oracle存储过程中如何检查表是否存在

在Oracle存储过程中如何检查表是否存在在Oracle数据库中,对于开发人员来说经常需要编写存储过程来完成一些复杂的业务逻辑。在编写存储过程时,有时需要在程序中判断某张表是否存在,以便根据表是否存在来执行不同的操作。本文将介绍在Orac
Oracle存储过程中如何检查表是否存在
2024-03-08

Oracle存储过程中如何检查表是否存在

在Oracle存储过程中如何检查表是否存在在Oracle数据库中,对于开发人员来说经常需要编写存储过程来完成一些复杂的业务逻辑。在编写存储过程时,有时需要在程序中判断某张表是否存在,以便根据表是否存在来执行不同的操作。本文将介绍在Orac
Oracle存储过程中如何检查表是否存在
2024-03-08

oracle如何在存储过程中判断表是否存在

oracle在存储过程中判断表是否存在的步骤:1、使用“user_tables`”系统表查询当前用户下的表信息,将传入的表名“p_table_name”与“table_name”字段进行比较,满足条件,则“COUNT(*)”会返回大于0的值
2023-07-10

Oracle存储过程:判断表是否存在的实现方法

Oracle数据库中存储过程是一种特定类型的存储过程,用于在数据库中执行一系列的SQL语句和数据操作。在实际的数据库开发工作中,有时候我们需要判断某个表是否存在于数据库中,这样可以在存储过程中做一些判断和逻辑处理。下面我们将介绍如何在Ora
Oracle存储过程:判断表是否存在的实现方法
2024-03-08

Oracle存储过程编写:判断数据库表是否存在

在Oracle数据库中,存储过程是一种可以保存并重复使用的一组SQL语句的集合,可以实现一定的逻辑功能。在编写Oracle存储过程的过程中常常会涉及到判断数据库表是否存在的需求,以便在后续处理中根据表的存在与否做出相应的操作。下面我们将介绍
Oracle存储过程编写:判断数据库表是否存在
2024-03-08

oracle怎么判断表是否存在并删除

Oracle数据库可以通过查询数据字典视图来判断表是否存在,并可以使用DROP TABLE语句来删除表。以下是一个示例SQL查询和操作:判断表是否存在:SELECT table_nameFROM user_tablesWHERE tab
oracle怎么判断表是否存在并删除
2024-04-09

Oracle数据库开发:编写存储过程判断表是否存在

在Oracle数据库开发中,编写存储过程来判断表是否存在是一项常见的任务。在数据库开发中,存储过程是一段预先编译的代码块,用于实现特定的功能或逻辑。通过编写存储过程来判断表是否存在,可以方便地对数据库进行管理和操作。本文将介绍如何在Orac
Oracle数据库开发:编写存储过程判断表是否存在
2024-03-09

SQLServer判断数据库、表、列、视图、存储过程、函数是否存在总结

这篇文章主要介绍了SQLServer判断数据库、表、列、视图、存储过程、函数是否存在,本文是一篇总结篇,结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2023-05-19

SQL Server判断数据库、表、列、视图、存储过程、函数是否存在总结

目录一、前言概述二、数据库相关的判断2.1、判断数据库是否存在三、数据表相关的判断3.1、判断数据表是否存在3.2、判断临时表是否存在3.3、判断表是否存在某列3.4、判断列是否自增列3.5、判断表中是否存在索引四、视图相关的判断4.1、判
2023-05-05

编程热搜

目录