优化前:
在订单页面,会加载一个函数,先生成一条订单,在插入新订单成功后,我去数据库交互,获取当前goods表的最大id,作为当前插入订单的id。
这样做的缺点:
虽然在大部分情况下,maxId和真实的新订单Id是相同的,但是一旦并发量足够大,就会出现:最大id与当前用户的生成的订单的id不相同,从而导致,在倒计时结束时,删除错订单。
再去获取maxId增加了数据库的操作,一定程度上加大了出错率。
优化的做法:
使用account和buyTime作为检索条件,
buyTime是1970年来目前的秒数,有一定程度上唯一性,再加上用户的手机号,已经是完全唯一性。
因为(在我的项目中)同一个用户是不可能在同一秒内进行两次操作。
而且,很好地解决了上面的两个缺点。