咨询一个多线程查询、更新mysql问题

有两张表,t1是机器信息表,机器名唯一,字段是:id,机器名称name,正在执行的任务数tasks;t2是任务记录表:id,机器名称name,任务状态。

接口1:每次调用此需要生成一个任务,原则是:从t1表中选择当前任务数最小的一个机器,在t2表中插入任务记录,状态是执行中,更新t1表中此机器的任务数+1。
接口2:任务执行完成后会调用此接口,将t2表中任务记录状态改成完成,并将t1表中对应的机器的正在执行任务数-1。

对于这两个接口,service层怎么实现好一点,特别是多线程情况下,同时调用接口1和接口2时,是不是得锁整张表t1啊,不然接口2里面需要更改t1中某个机器的任务数,那么对于接口1来说,在接口2执行前后获取到的数据可能就不一样,所以是否应该锁表,感觉想把锁粒度控制在行锁级别不太可行啊。
#mysql##java##多线程##面试##mysql锁##mysql面试题#
全部评论

相关推荐

但听说转正率很低,我现在有在实习了,好纠结要不要去
熬夜脱发码农:转正率低归低,但是实习的经历你可以拿着,又不是说秋招不准备了
点赞 评论 收藏
分享
05-21 15:47
门头沟学院 Java
浪漫主义的虹夏:项目有亮点吗,第一个不是纯玩具项目吗,项目亮点里类似ThreadLocal,Redis储存说难听点是花几十分钟绝大部分人都能学会,第二个轮子项目也没体现出设计和技术,想实习先沉淀,好高骛远的自嗨只会害了自己
点赞 评论 收藏
分享
程序员牛肉:主要是因为小厂的资金本来就很吃紧,所以更喜欢有实习经历的同学。来了就能上手。 而大厂因为钱多,实习生一天三四百的就不算事。所以愿意培养你,在面试的时候也就不在乎你有没有实习(除非是同级别大厂的实习。) 按照你的简历来看,同质化太严重了。项目也很烂大街。 要么换项目,要么考研。 你现在选择工作的话,前景不是很好了。
点赞 评论 收藏
分享
评论
点赞
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务