做实战的时候遇到一个问题:
已知有菜品分类(表示菜品的种类),然后还有就是菜品,我们在删除菜品分类的时候要先知道菜品分类下有没有菜品,如果有菜品就不能删除,没有菜品才可以删除。但是这个是否会和添加菜品产生线程安全问题?这边查询数据库没有,但是删除之前,另一个用户添加了该种类下的菜品,但是另一个不知道,就会删除,逻辑就出错了。
但是如果加同步的话,需要添加菜品逻辑和删除逻辑加同一个锁对象把?那么此时删除逻辑,添加菜品以及二者都会被阻塞,性能太差了,那请问有其他解决办法吗(除了直接在sql里添加条件判断)
线程安全问题解决方法
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
8条回答 默认 最新
- 社区专家-Monster-XH 2023-02-07 10:31关注
两种锁,悲观锁和乐观锁。
乐观锁,比如使用版本号或时间戳。你在删除菜品分类之前,检查版本号或时间戳和数据亏对不对得上,对不上,就是别人改了菜品,那就不能删。
悲观锁,就是用行锁或表锁来限制修改数据。删除菜品分类时,给类先加个锁,放被人在你检查前下手,这样,添加菜品的操作就被阻塞了,直到你释放锁才行。但这可能会造成锁定资源过长的问题,还要考虑性能稳不稳。
-使用数据库事务是一种解决方案。在删除菜品分类之前可以使用数据库的唯一约束来确保菜品分类下没有菜品。
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用
悬赏问题
- ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
- ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
- ¥15 手机接入宽带网线,如何释放宽带全部速度
- ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
- ¥15 ETLCloud 处理json多层级问题
- ¥15 matlab中使用gurobi时报错
- ¥15 这个主板怎么能扩出一两个sata口
- ¥15 不是,这到底错哪儿了😭
- ¥15 2020长安杯与连接网探
- ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么