問題描述
有一天搏明,測(cè)試妹子W向我提了一個(gè)BUG闪檬,問題描述如下,當(dāng)操作動(dòng)作D時(shí)虚循,動(dòng)作D可以看作更新样傍,更新我當(dāng)前選擇的那一條數(shù)據(jù),妹子W看到操作D成功頁(yè)面中多出一條一樣的數(shù)據(jù)衫哥,期望的結(jié)果是只會(huì)更新當(dāng)前選擇行的數(shù)據(jù),并不會(huì)新增多余的數(shù)據(jù)斗蒋。
問題原因
開始的時(shí)候,我認(rèn)為代碼有問題,查看一下代碼妇押,應(yīng)該沒有太大的問題,普通操作動(dòng)作D時(shí)俊马,數(shù)據(jù)會(huì)更新肩杈,不會(huì)新增多余的數(shù)據(jù),但是在出現(xiàn)異常時(shí)艘儒,這個(gè)問題夫偶,就會(huì)復(fù)現(xiàn)出來(lái),我當(dāng)前猜想應(yīng)該有事務(wù)有關(guān)系兵拢。
現(xiàn)在我先說明一下,動(dòng)作D的業(yè)務(wù)邏輯访惜,當(dāng)我們點(diǎn)擊動(dòng)作D時(shí)腻扇,首先會(huì)調(diào)用更新操作,更新數(shù)據(jù)衙解,此處的更新為先刪除原先的數(shù)據(jù)蚓峦,后重新插入數(shù)據(jù),更新結(jié)束后暑椰,繼續(xù)向下執(zhí)行其它邏輯。在我Debug的時(shí)候避消,發(fā)現(xiàn)在刪除的邏輯上事務(wù)有回滾,唯一的是插入數(shù)據(jù)竟沒有回滾岩喷,我以為是Mybatis plus有什么特殊的騷操作,原諒當(dāng)時(shí)無(wú)知的我,我在Google上找了好多文章就是沒找到這個(gè)問題產(chǎn)生的原因婶溯。最后偷霉,只能把這個(gè)BUG先放一邊,忙著修復(fù)其它Bug叙身。
當(dāng)我把所有的事情都忙完了硫狞,我又重新看了動(dòng)作D的邏輯,看到插入的邏輯妓忍,這個(gè)插入數(shù)據(jù)的邏輯我是直接調(diào)用同事寫好的方法世剖,我看到產(chǎn)生BUG的原因,因?yàn)椴迦氲臄?shù)據(jù)有可能有許多旁瘫,那段的邏輯使用了多線程插入數(shù)據(jù)。多線程影響事務(wù)回滾惠况,事務(wù)沒辦法回滾多線程的數(shù)據(jù)宁仔。
解決步驟
發(fā)現(xiàn)問題后,當(dāng)然要解決問題权埠,多線程影響事務(wù)回滾煎谍,那我就用最笨的方法,重新寫一段插入數(shù)據(jù)的邏輯呐粘,解決這個(gè)事務(wù)問題转捕。寫完代碼本地測(cè)試唆垃,當(dāng)出現(xiàn)異常時(shí),刪除操作回滾數(shù)據(jù)辕万,新增操作回滾數(shù)據(jù),解決完問題,發(fā)到測(cè)試環(huán)境讓妹子W再測(cè)試一遍涡戳,美滋滋脯倚!
總結(jié)
這個(gè)問題,浪費(fèi)了我許多時(shí)間推正,上網(wǎng)找資料,還有掉頭發(fā)再沧,最后才發(fā)現(xiàn)問題的原因尊残,事實(shí)說明我平時(shí)粗心大意,沒有看清楚代碼的邏輯顷扩,遇到問題首先不是看代碼慰毅,而是上網(wǎng)找解決方法。這個(gè)壞習(xí)慣影響著我婶芭,以后的工作中應(yīng)該避免這類事情的出現(xiàn)统台。還有一個(gè)問題,就是使用別人的代碼一定要看中間的邏輯贱勃,別人使用沒有問題谤逼,并不代表你使用那部分代碼也沒有問題流部,所以工作中要仔細(xì)纹坐。