前幾天耳舅,數(shù)據(jù)自動同步出現(xiàn)了bug碌上,使用的框架是tp3.2倚评,一條本該帶條件的更新語句,結果不帶條件的幫我把數(shù)據(jù)全部更新了馏予。辛虧影響的用戶數(shù)據(jù)才一百多天梧,手動修復了一下午。
又去翻了一下文檔霞丧,發(fā)現(xiàn)文檔有寫呢岗,不能說是tp的bug。只能說是沒認真看文檔蛹尝。
看了一下源碼后豫,tp在操作數(shù)據(jù)的時候,會把不存在的字段自動忽略掉突那。
正式環(huán)境默認開啟數(shù)據(jù)字段緩存挫酿,而緩存機制是每個模型對應一個字段緩存文件(注意:并非每個數(shù)據(jù)表對應一個字段緩存文件),命名格式是:數(shù)據(jù)庫名.數(shù)據(jù)表前綴+模型名(小寫).php
因為之前沒留意這個愕难,數(shù)據(jù)庫里弄了兩個表app_dc_video和app_ky_video,表是不同的模塊使用的早龟,結構和數(shù)據(jù)都不一樣,第一個是表是另一個同事后來加的猫缭,我在我的代碼模塊里命名了videoModel拄衰,他后來也在他代碼模塊用了videoModel,兩個表的字段緩存名字是一樣的饵骨,所以肯定有一個會覆蓋另一個翘悉。導致數(shù)據(jù)更新出現(xiàn)了bug。
恩居触,故事告訴我們妖混,使用框架一定要通讀文檔。