关于PLSQL中的一些问题总结:在PLSQL中书写DDL等

这篇博客总结了在PLSQL中执行DDL(如create、drop、truncate)和DML(insert、delete、update)的注意事项。在PLSQL中,DDL需要使用动态SQL语句,即在declare部分声明变量并在begin和end之间用execute immediate执行。DML可以直接执行,但若在同一个PLSQL块中创建表并插入数据,也需要使用execute immediate以避免表不存在的错误。对于select语句,必须配合into语句才有执行意义。此外,文章还提到了创建一系列与系名相关的查询存储过程。
摘要由CSDN通过智能技术生成

关于问题前导,使用的数据表中涉及到的字段和类型:


在PLSQL中create、drop、truncate等DDL是没有办法直接执行的。

必须要使用:

Execute immediate ‘DDL语句’

但是我发现这样并不能执行!后面查阅发现,oracle中执行DDL语句需要使用变量的形式:

即 所谓的动态SQL语句

首先在declare中声明变量(  例如:sql varchar2(200):= ‘create table tmp(name varchar2(20), age number(3))’   ),再在begin和end之间 execute immediate才可以!

 

DML

关于DML insert、delete、update是可以直接执行的,而且通过SQL对象会返回受到影响的行数。

但是这里需要注意的是:如果你是在同一个PLSQL中创建了表,同时想在这个PLSQL中insert数据的话,就必须要小心了!!!

也要使用:executeimmediate的方式来执行:注意,最好也是通过变量的形式执行:

直接把语句通过 executeimmediate引在后面当然可以,但

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值