出现死锁时如何递归调用程序?
P粉060112396
P粉060112396 2023-08-30 22:10:39
0
1
359
<p>我的作业“存储过程”整夜运行。我时不时地陷入僵局。我想编写一个代码,如果发现死锁,它将在 15 分钟后执行相同的过程最多 3 次。</p> <p>假设现在时间是上午 10 点。然后在上午 10 点运行它,如果发现死锁,则在上午 10:15 再次调用该作业,然后在上午 10:30“如果死锁”,然后在上午 10:45“如果死锁”。如果最后一次运行死锁,则完全终止作业。</p> <p>这是我所做的。</p> <pre class="brush:php;toolbar:false;">DECLARE totalTrys INT DEFAULT 0; DECLARE EXIT HANDLER FOR SQLEXCEPTION BEGIN GET DIAGNOSTICS CONDITION 1 @err_num = MYSQL_ERRNO; if(@err_num = 1213 AND totalTrys < 4) THEN SET totalTrys = totalTrys + 1; SELECT SLEEP(900); CALL guardi.prod_update_guardi_accounts(); END IF; END;</pre> <p>这是一种有效的方法吗?除了消除死锁之外还有更好的方法吗?</p>
P粉060112396
P粉060112396

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!