前幾天,數(shù)據(jù)自動同步出現(xiàn)了bug,使用的框架是tp3.2,一條本該帶條件的更新語句,結(jié)果不帶條件的幫我把數(shù)據(jù)全部更新了。辛虧影響的用戶數(shù)據(jù)才一百多,手動修復(fù)了一下午。
又去翻了一下文檔,發(fā)現(xiàn)文檔有寫,不能說是tp的bug。只能說是沒認(rèn)真看文檔。
看了一下源碼,tp在操作數(shù)據(jù)的時候,會把不存在的字段自動忽略掉。
正式環(huán)境默認(rèn)開啟數(shù)據(jù)字段緩存,而緩存機(jī)制是每個模型對應(yīng)一個字段緩存文件(注意:并非每個數(shù)據(jù)表對應(yīng)一個字段緩存文件),命名格式是:數(shù)據(jù)庫名.數(shù)據(jù)表前綴+模型名(小寫).php
因?yàn)橹皼]留意這個,數(shù)據(jù)庫里弄了兩個表app_dc_video和app_ky_video,表是不同的模塊使用的,結(jié)構(gòu)和數(shù)據(jù)都不一樣,第一個是表是另一個同事后來加的,我在我的代碼模塊里命名了videoModel,他后來也在他代碼模塊用了videoModel,兩個表的字段緩存名字是一樣的,所以肯定有一個會覆蓋另一個。導(dǎo)致數(shù)據(jù)更新出現(xiàn)了bug。
恩,故事告訴我們,使用框架一定要通讀文檔。