如何通过提示定位调用 delete 的代码?
问题背景:
注册用户后,执行 update 修改用户状态,但无意中执行了 delete 操作,导致用户信息丢失。
问题定位:
根据控制台提示信息:
org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.mooc.house.biz.mapper.UserMapper.delete
我们可以了解到:
通过分析提示信息中的调用栈,我们可以逐步定位到调用 delete 操作的代码:
因此,delete 操作是由 mailservice.enable 触发的。
далее,通过查看 userservice.enable 和 mailservice.enable 的调用栈,我们可以找到直接调用 mailservice.enable 的代码:
由此,我们可以确定执行 delete 操作的代码是 usercontroller.verify。
总结:
通过分析控制台提示信息中的调用栈,可以逐步定位到执行 delete 操作的代码。在此示例中,usercontroller.verify 调用了 mailservice.enable,而 mailservice.enable 中的 mailservice.onremoval 触发了 usermapper.delete 的执行。