专栏首页Jerry的SAP技术分享编程面试题:编写一个会造成数据库死锁的应用

编程面试题:编写一个会造成数据库死锁的应用

相信对于”开发一个会产生死锁的Java应用”这类需求,大家都能顺利完成。但是如果题目要求得更具体一些,要求这个死锁发生在数据库层面,应该怎样完成呢?

下面我提供一种答案,采用SAP的编程语言ABAP(Advanced Business Application Programming)实现。

我们从ABAP帮助文档中得知,SELECT SINGLE FOR UPDATE在从数据库读取一条记录时,会在数据库里将该条记录上锁。帮助文档里也提到,如果编程不恰当,会引起死锁(deadlock)。

所以我们的答题就利用SELECT SINGLE FOR UPDATE这条语句。

首先在数据库里插入两条记录,主键分别为Z01和Z02。

开发两个应用,第一个应用依次锁Z01和Z02。

REPORT zlock1.

DATA: ls_prod TYPE zorder_header.

SELECT SINGLE FOR UPDATE * FROM zorder_header INTO ls_prod WHERE object_id = 'Z01'.

SELECT SINGLE FOR UPDATE * FROM zorder_header INTO ls_prod WHERE object_id = 'Z02'.

第二个应用依次锁Z02和Z01。

REPORT zlock2.

DATA: ls_prod TYPE zorder_header.

SELECT SINGLE FOR UPDATE * FROM zorder_header INTO ls_prod WHERE object_id = 'Z02'.

SELECT SINGLE FOR UPDATE * FROM zorder_header INTO ls_prod WHERE object_id = 'Z01'.

下面的步骤会造成数据库层面的死锁。

1. 以调试模式运行第一个应用,单步执行完代码第10行,成功锁住Z01。

2. 新开一个窗口,以调试模式运行第二个应用,单步执行完代码第10行,成功锁住Z02。

3. 回到应用1的窗口,继续执行。此时应用1试图锁Z02,但是Z02已经被应用2锁住了,因此应用1处于等待状态。

4. 回到应用2的窗口,继续执行。此时应用2试图锁Z01,但是Z01已经被应用1锁住了,所以应用2只有等待应用1释放出Z01的锁。但应用1此时也在等待应用2,因此造成了死锁。

ABAP和Java不同,一旦检测到死锁,应用会抛运行时异常并自动终止,异常信息里说得很清楚:Deadlock detected while executing transaction…

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 编程面试题:编写一个会造成数据库死锁的应用

    相信对于"开发一个会产生死锁的Java应用”这类需求,大家都能顺利完成。但是如果题目要求得更具体一些,要求这个死锁发生在数据库层面,应该怎样完成呢?

    Jerry Wang
  • 使用SAP connect发送HTML格式的邮件

    Jerry Wang
  • SAP云平台cf push命令报错误码44的解决方法

    我本地开发了一个nodejs应用,用cf push部署到CloudFoundry时报错:

    Jerry Wang
  • 我们如何衡量一个微服务实施的成功

    本次介绍的案例来自于我曾经服务过的客户 R,到今天已经5年整了。2013年的国庆后,我加入了客户 R 的其中一个产品团队,这个团队有三个项目:一个项目做日常维护...

    顾宇
  • JS基础 | Cocos Creator 开发环境搭建

    编程并不只是简单地写代码,而是要将编写的代码运行在指定平台环境上,在此之前我们还需要搭建生产代码的环境。

    张晓衡
  • 犀牛鸟人物 | 专访上海交通大学高晓沨老师

    ? 【导读】高晓沨,博士,上海交通大学计算机科学与工程系教授,博士生导师。2017年获得CCF-腾讯犀牛鸟基金,2018年获得腾讯广告犀牛鸟专项基金。主要研究...

    腾讯高校合作
  • nodejs连接MongoDB插入数据

    昨天介绍了一下MongoDB在shell下的正删改查,今天来讲一下在nodejs中如何连接数据库以及数据的插入!

    十月梦想
  • OGNL与值栈

    OGNL是Object-Graph Navigation Language的缩写,它是一种功能强大的表达式语言,通过它简单一致的表达式语法,可以存取对象的任意属...

    木瓜煲鸡脚
  • 如何从生信角度布局一篇5分的SCI

    下面给大家展现的是4篇2019年的5分生信文章。这4篇文章都是纯生信分析的文章并且在2019年还能登顶5分杂志。4篇文章每个都有自己的创新角度,我们一个一个来分...

    百味科研芝士
  • 用大白话告诉你小白都能看懂的Hadoop架构原理

    Hadoop 是目前大数据领域最主流的一套技术体系,包含了多种技术,例如 HDFS(分布式文件系统),YARN(分布式资源调度系统),MapReduce(分布式...

    良月柒

扫码关注云+社区

领取腾讯云代金券

玩转腾讯云 有奖征文活动