إذا قمت بإسقاط جدول ولم يكن الجدول موجودًا ، أحصل على خطأ
سؤال
أحتاج إلى إسقاط طاولة وجعل لوحة جديدة. إذا قمت بإسقاط الجدول ولم يكن الجدول موجودًا ، أحصل على خطأ
كيف يمكنني التحقق مما إذا كان الجدول موجودًا؟
أنا أعمل على Oracle 11g
شكرا مقدما.
المحلول
يمكنك أن تفعل شيئًا كهذا:
DECLARE v_exist PLS_INTEGER;
BEGIN
SELECT COUNT(*) INTO v_exist
FROM user_tables
WHERE table_name = 'YOURTABLEHERE';
IF v_exist = 1 THEN
EXECUTE IMMEDIATE 'DROP TABLE YOURTABLEHERE';
END IF;
نصائح أخرى
DECLARE
eTABLE_OR_VIEW_DOES_NOT_EXIST EXCEPTION;
PRAGMA EXCEPTION_INIT(eTABLE_OR_VIEW_DOES_NOT_EXIST, -942);
BEGIN
EXECUTE IMMEDIATE 'DROP TABLE SCHEMA.WHATEVER';
EXCEPTION
WHEN eTABLE_OR_VIEW_DOES_NOT_EXIST THEN
NULL;
END;
مشاركة واستمتع.
شيء مثل
select count(*) from user_tables
where table_name= :table name
أو
select count(*) from dba_tables
where owner = :table owner
and table_name = :table name
أو بديل ثقيل:
begin execute immediate 'drop table table_name';
exception when others then null;
end;
لقد كنت أستخدم الإجراء التالي لرعاية هذا:
create or replace procedure drop_table_if_exists ( p_table_name varchar2 )
is
it_exist number;
begin
select count(*)
into it_exists
from user_tables
where table_name = p_table_name
;
if it_exists >= 1 then
execute immediate 'drop table '||p_table_name;
end if;
end;
/
exec drop_table_if_exists ( 'TABLE_TO_DROP' );
لا تنتمي إلى StackOverflow