INSERT INTO `video_day`(`dateStr`) VALUES ('20190920') ON DUPLICATE KEY UPDATE total_sum=88
1、做一个项目中碰到这样一个问题,需要对一个用户行为进行分日统计,表的字段,有年、月、日等字段,用户当日产生行为之后,需要对行为进行统计,这样就会涉及到一个问题:如果当日记录不存在,就需要在表中建立这样一条记录,如果记录存在,只需要对某些字段进行更新即可。
2、之前遇到这样的问题总是分两步操作,比较麻烦,还有些高并发的问题。然后发现了上面的方法。大概意思就是插入,如果插入的时候出错了,就更新,什么情况会插入报错呢,就是违反了唯一索引。只需要在表中新增一个字段,年+月+日,并设置为唯一索引。问题就解决了。
本文介绍了一种使用SQL语句优雅解决数据分日统计问题的方法。通过INSERT...ON DUPLICATE KEY UPDATE语句,可以实现在记录不存在时插入新记录,在记录已存在时更新指定字段,有效避免了高并发下分步操作的复杂性。
&spm=1001.2101.3001.5002&articleId=101071880&d=1&t=3&u=39ea9cbf2fd046df9882d7b7a17fddfe)
573

被折叠的 条评论
为什么被折叠?



