oracle insert if not exists,create table if not exists?

这篇博客介绍了如何用PL/SQL编写一个过程,该过程检查指定的所有者和表名是否存在,如果不存在,则创建表格。通过示例展示了如何在Oracle数据库中实现这个功能,包括创建和调用过程的步骤,以及错误处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

John,

It is up to the user to decide, not to you. You have your believe that this is far complicated but it the user wants to enhance his knowledge with learning some PL/SQL code, than let him go ahead.

About "the flawless", well, it can be corrected just creating a procedure PL/SQL and pass as parameter the owner and the table_name as this:

CREATE OR REPLACE PROCEDURE CREATE_TABLE_IF_NOT_EXIST (l_owner IN DBA_TABLES.OWNER%TYPE, l_table_name IN DBA_TABLES.TABLE_NAME%TYPE) IS

l_check  VARCHAR2(10);

BEGIN

SELECT 'VALID' into l_check FROM dba_tables where table_name = l_table_name and owner = l_owner;

DBMS_OUTPUT.PUT_LINE('TABLE '|| l_owner ||'.'|| l_table_name ||' ALREADY EXIST.');

EXCEPTION WHEN NO_DATA_FOUND then

EXECUTE IMMEDIATE 'create table '|| l_owner ||'.'|| l_table_name ||' ( ID VARCHAR2(10))';

DBMS_OUTPUT.PUT_LINE('TABLE '|| l_owner ||'.'|| l_table_name ||' CREATED SUCESSFULLY.');

END;

/

Procedure created.

SYS> EXEC CREATE_TABLE_IF_NOT_EXIST ('SCOTT','NO_TABLE_JOHN');

TABLE SCOTT.NO_TABLE_JOHN CREATED SUCESSFULLY.

PL/SQL procedure successfully completed.

SYS> DROP TABLE SCOTT.NO_TABLE_JOHN;

Table dropped.

SYS> EXEC CREATE_TABLE_IF_NOT_EXIST ('SCOTT','NO_TABLE_JOHN');

TABLE SCOTT.NO_TABLE_JOHN CREATED SUCESSFULLY.

PL/SQL procedure successfully completed.

SYS> EXEC CREATE_TABLE_IF_NOT_EXIST ('SCOTT','NO_TABLE_JOHN');

TABLE SCOTT.NO_TABLE_JOHN ALREADY EXIST.

PL/SQL procedure successfully completed.

SYS> DROP TABLE SCOTT.NO_TABLE_JOHN;

Table dropped.

Also, you are on PL/SQL fórum, so the more correct would be to answer it as a PL/SQL code.

Regards.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值