`
huang552
  • 浏览: 102671 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

oracle死锁模拟

 
阅读更多

用PLSQL Developer新建一个command window窗口,执行

update A g set g.status='9' where seq_id in(3407144);

--休眠8秒

exec dbms_lock.sleep(8);

update A g set g.status='9' where seq_id in(3407146);

commit;

 

新建一个command window窗口,执行

update A g set g.status='4' where seq_id in(3407146);

--休眠20秒

exec dbms_lock.sleep(20);

update A g set g.status='4' where seq_id in(3407144);

 

commit;

 

 

两个相互锁的sql执行,两个执行sql的事务是一起提交的,最后查数据,发现两条记录最后的状态是4,说明以最后提交的数据为准

分享到:
评论

相关推荐

    BLOG_Oracle_lhr_Oracle死锁的分类及其模拟.pdf

    【Oracle死锁的分类及其模拟】这篇博客主要探讨了Oracle数据库中的死锁问题,包括死锁的基本概念、分类以及如何进行模拟。以下是该主题的详细解释: **死锁概述** 死锁是数据库系统中常见的问题,它发生在两个或多...

    Oracle 死锁处理

    下面将详细讨论Oracle死锁的原因、具体分析、示例以及解决办法。 1. **死锁原因分析** - 行级锁:Oracle数据库使用行级锁来支持并发操作,当两个事务同时尝试获取对方已持有的锁时,就可能导致死锁。 - 外键约束...

    Oracle数据库死锁查询语句

    Oracle还提供了一个名为`DBMS_LOCK`的PL/SQL包,可以用于手动模拟死锁或者解除死锁。例如,`DBMS_LOCK.REQUEST`函数用于请求锁,而`DBMS_LOCK.RELEASE`用于释放锁。 当遇到死锁时,Oracle数据库的死锁检测机制会...

    java线程死锁代码示例

    为了模拟死锁,我们使用 synchronized 块来锁住这两个资源,并在锁住的过程中进行 sleep 操作,以便模拟资源的占用。 5. synchronized 块的使用:在 Java 中,synchronized 块可以用来锁住一个对象,以便实现线程...

    数据库死锁检测工具

    在实际应用中,数据库系统如MySQL、Oracle和SQL Server都内置了死锁检测和处理机制。例如,MySQL的InnoDB存储引擎会自动检测死锁,并选择一个事务进行回滚。同时,DBA还可以通过调整事务隔离级别、合理设计锁粒度、...

    oracle课件

    4. 事务处理与并发控制:理解事务的概念,学习如何控制事务的提交和回滚,以及Oracle的锁定机制和死锁处理。 5. 性能优化:通过实验了解SQL查询优化,使用 Explain Plan 分析查询执行计划,调整索引和表分区,以及...

    oracle编程艺术代码

    5. 并发控制:理解行级锁定、多版本并发控制(MVCC)以及死锁检测和避免。 三、源码分析 压缩包中的源码可以用于实践以下技术: 1. 示例数据库创建:如何从零开始构建一个简单的Oracle数据库,包括表空间、用户、...

    oracle培训课件在(中博)

    "测试题目.ppt"可能是一系列的练习题或者模拟测试,旨在检验学习者对Oracle SQL的理解和运用。通过解答这些题目,学习者可以巩固所学知识,提高实际问题解决能力。 "数据库并发操作.ppt"则涉及到多用户同时访问...

    Oracle 课程设计案例精编

    6. **事务和并发控制**:理解事务的ACID特性(原子性、一致性、隔离性、持久性),以及Oracle中的锁定机制和死锁处理。 7. **备份与恢复**:学习如何进行数据库备份,理解完整备份、增量备份和差异备份的区别,以及...

    Oracle BPEL

    - **模拟测试**:利用模拟工具对流程进行初步的测试。 - **实时调试**:部署流程到Oracle BPEL Process Manager环境中,并通过监控工具查看流程的执行情况。 #### 四、高级特性 ##### 1. 高级集成 - **消息路由**...

    OCP Oracle9i 性能调整学习指南.pdf

    - **死锁预防与解决**: 掌握如何避免死锁发生,以及一旦发生死锁时的解决策略。 #### 七、高级主题 - **实时应用集群 (RAC)**: 介绍 Oracle9i RAC 的特点和优势,以及如何对其进行性能调整。 - **备份与恢复策略**:...

    OCP考试环境的模拟器

    5. 故障排查:考生应能处理常见的数据库错误,例如锁定、死锁问题,理解如何查看和分析数据库日志,以及如何使用SQL*Plus和Enterprise Manager Cloud Control进行故障排查。 6. 安全性:理解和实施数据库安全策略,...

    Oracle面试复习(二)

    - BOOLEAN在Oracle中不直接支持,但可以通过CHAR或NUMBER模拟。 3. **表和索引**: - 创建、修改和删除表(CREATE, ALTER, DROP)。 - 索引的作用是加快查询速度,有B树索引、位图索引、唯一索引和非唯一索引等...

    oracleOCP-53考题中文解析+模拟器

    压缩包中的"VCE模拟器-053"可能是一个虚拟化考试环境,用于模拟真实的1Z0-053考试,帮助考生熟悉考试格式,进行自我测试和评估。 10. **文档资源** "53.docx"、"53-3.docx"、"53-2.docx"和"1Z0-053.pdf"可能是...

    Oracle Locking Survival Guide

    Oracle通过死锁检测和回滚机制来解决这个问题。当检测到死锁时,数据库会选择一个事务进行回滚,以打破死锁循环。 为了诊断和分析锁定问题,Oracle提供了一些实用工具,例如`V$SESSION`、`V$LOCK`视图以及`DBA_...

    oracle 10g 042

    11. **并发控制**:了解锁定机制、多版本并发控制(MVCC)以及死锁检测和解决。 12. **数据库设计与架构**:理解规范化理论,以及如何创建高效的设计来满足业务需求。 13. **数据库维护任务**:定期执行的数据库...

    Oracle数据库性能优化实务闩锁及闩锁优化.ppt

    闩锁是一种机制,用于保护Oracle数据库的核心内存结构,防止多个进程同时访问核心内存引起的冲突和死锁。 在Oracle数据库中,闩锁是通过LATCH(Latch)来实现的。LATCH是一种轻量级的锁机制,用于保护Oracle数据库...

    oracle最新认证题库资料

    "Actualtests Oracle 1Z0-211 V11.10.08"这个文件名称可能指的是一个模拟考试题库,用于帮助考生准备1Z0-211考试。V11.10.08可能是该题库的版本号,表示这是题库的第11次更新,版本号10.8,通常这样的更新会包含最新...

    韩顺平oracle视频笔记四(事务)

    5. **死锁**:当两个或更多事务因等待对方释放资源而陷入无限循环的情况,以及如何通过设置事务超时和死锁检测机制来避免。 6. **Oracle的并发控制**:如多版本并发控制(MVCC)和行级锁定机制。 7. **闪回事务**:...

    Oracle9i实验的答案:作为Oracle9i实验指导书的详细答案

    实验应包含备份计划的制定,以及在模拟故障场景下如何执行恢复操作。 七、性能优化 Oracle9i提供了一系列性能优化工具和方法,如SQL*Profiler用于查找性能瓶颈,Explain Plan分析查询执行计划,以及调整表分区和...

Global site tag (gtag.js) - Google Analytics