存储过程中慎用 execute immediate ,

execute immediate 执行DDL语句一定要小心,否则会造成数据一至性问题。

[@more@]

1,

create table t1( id1 number );

2,

begin

insert into t1 values (101) ;

execute immediate ' create table t2 (id1 number ) ';

end;

/

PL/SQL procedure successfully completed

数据已经被提交,无论你是否COMMIT。

如果一个过程中有多个DML语中,中间混杂了类似的DDL动态语句,就会造成DDL之前的语句提交,尽管DDL之后的语句失败了,最终也无法将整个事物回滚到一致性状态。

3,

begin

insert into t1 values (101) ;

execute immediate ' alter session enable parallel dml ' ;

end;

/

ORA-12841: Cannot alter the session parallel DML state within a transaction

ORA-06512: at line 8

但是"alter session" 这个DDL 语句不能在事物中执行。 必须首先提交或回滚事物。

oracle execute存过,存储过程中慎用 execute immediate相关推荐

  1. execute immediate在存储过程中的使用

    execute immediate 在存储过程中使用较为频繁,其作用是巨大的,下面简单介绍其基本用法 1:在存储过程中,我们知道只能使用DML语句,那么如果要使用DDL语句呢,就得使用execute ...

  2. 在存储过程中调用execute immediate 执行 create table语句报TBR-17004: Permission denied

    错误描述: 在存储过程中调用execute immediate 执行 create table语句报错TBR-17004 权限不正确,但是直接执行该语句不报错. SQL> conn sys/ti ...

  3. ORACLE动态sql在存储过程中出现表或视图不存在的解决方法

    ORACLE动态sql在存储过程中出现表或视图不存在的解决方法 CREATE OR REPLACE PROCEDURE P_test is strsql varchar2(2000); BEGIN   ...

  4. 存储过程中调用EXECUTE IMMEDIATE的“权限不足”问题

    使用plsql 动态创建表时,用户需要具有create any table 权限 例如: create or replace procedure create_table_test is tmpstr ...

  5. Oracle数据库游标在存储过程中的使用

      作为关系型数据库市场的老大,Oracla占有举足轻重的地位.虽然在操作上不如SQLSERVER那样方便,但是他的强大的功能<br>还是吸引来大批大批的追随着.本人作为ORACLE菜鸟, ...

  6. oracle学习-PL SQL 存储过程中循环

    PL SPL 提供了3中不同类型的循环结构 -- 实例:索引 loop_counter从1开始,到10 结束,循环共执行10次 FOR loop_counter IN 1 .. 10 LOOP...可 ...

  7. oracle execute immediate create,execute immediate在oracle存储过程中的使用

    execute immediate 在存储过程中使用较为频繁,其作用是巨大的,下面简单介绍其基本用法 1:在存储过程中,我们知道只能使用DML语句,那么如果要使用DDL语句呢,就得使用execute ...

  8. oracle数据存储过程 中的循环 for 拼接字符串,oracle存储过程中使用字符串拼接

    1.使用拼接符号"||" v_sql := 'SELECT * FROM UserInfo WHERE ISDELETED = 0 AND ACCOUNT =''' || vAcc ...

  9. mysql存储过程into_MySQL存储过程中使用SELECT …INTO语句为变量赋值

    使用SELECT -INTO语句为变量赋值 在MySQL存储过程中,可以使用SELECT -INTO语句对变量进行赋值,该语句在数据库中进行查询,并将得到的结果赋值给变量.SELECT -INTO语句 ...

最新文章

  1. GHOST WIN8 64位软件自选安装专业优化版 201307 V1.0
  2. 编译安装php之安装libiconv-1.14.tar.gz出错解决方法
  3. Java爬虫抓取网页
  4. SpringBoot 异常回滚 事务的使用___Springboot @Transactional 事务不回滚
  5. Lightroom 如何安装lrplugin格式插件
  6. Oracle树反向查询的优化(转载)
  7. 团队天梯赛L1-001
  8. 16个 Redis 常见使用场景,面试有内容聊啦
  9. Java之小球碰撞反弹
  10. 风控建模二、特征工程---通用
  11. Vue使用axios图片上传报错500
  12. 史上最牛的Linux视频教程—兄弟连 学习笔记1
  13. 迷你云服务器怎么开,迷你世界迷你云服怎么开_迷你世界迷你云服打开方法_玩游戏网...
  14. 移动硬盘做PE启动盘的技巧
  15. cf英文名字格式好看的_cf好看的英文名字格式:、I (~) you ?
  16. tekla钢筋组弯钩方向
  17. Flink实战——每隔5秒,统计最近10秒的窗口数据
  18. android persist属性使用
  19. gunicorn的命令参数解释
  20. #P00603. 倒水

热门文章

  1. 使用马哈鱼SQLFLow 1 分钟获取复杂 SQL 语句的血缘关系
  2. 本人热衷于的小米手机配置和图片,给大家参考一下哦----zhoudianzhang
  3. 小米手机必败无疑 安卓系统大战爆发前夕
  4. RadioGroup和RadioButton
  5. 「雷锋前线」攻破一把智能门锁的N种方法
  6. 常用word快捷键大全
  7. php网页是什么样,网页php开发是什么意思
  8. 魅族升级鸿蒙,升级鸿蒙两种态度,“机智”的魅族与“鸡贼”的小米
  9. Vector - 常用CAN工具 - CANoe软件安装常见问题
  10. 大数据中的用户画像——让机器懂用户