您好,登錄后才能下訂單哦!
上篇文章分享了在項目實戰中自定義Mybatis的TypeHandler來處理枚舉類型。文章結尾也指出了美中不足之處,那就是每次都需要指定我們自定義的枚舉TypeHandler。 隨著項目枚舉類型的增多,每次都要寫一遍這個會令人很反感。那么,本次我們就來解決這一痛點。
思路分析
為了方便大家理解, 貼上Mybatis中的TypeHandlerRegistry的相關部分源碼:
實戰
SqlSessionFactoryBean
由于我們項目使用了Spring, 是用Spring集成的Mybatis(廢話,大家都是這么干的)。Spring通過SqlSessionFactoryBean來初始化啟動Mybatis。 因此,我們應該在它身上下手,然而,一切并不是那么順利。
查看了一下SqlSessionFactoryBean的源碼,發現SqlSessionFactoryBean并沒有任何地方可以讓我們切入, 進而來調用TypeHandlerRegistry進行注冊我們的枚舉。 更令人蛋疼的是其所有屬性全是private, 這下不僅AOP切入不行,連通過繼承偷懶都不行了。
作罷,咱只有老老實實的重寫一遍SqlSessionFactoryBean的代碼了(copy還不簡單)。
DefaultSqlSessionFactoryBean
代碼量比較多,就只貼關鍵代碼了。步驟如下:
切記, 以上代碼要在這個代碼之前執行:
因為, xmlMapperBuilder.parse()方法會開始解析我們所有的所有mapper.xml的配置文件了,這時候會把resultMap也解析了,這就會導致我們自定義的TypeHandler不生效。
切記! 切記
最后
以上,代碼算是完工了,記得在Spring的配置文件中, 將SqlSessionFactoryBean替換為我們的DefaultSqlSessionFactoryBean。 不然我們的活就是白干了。
接下來,就可以開始浪了, 之前我們需要這樣寫:
<resultMap> ... <result column="status" jdbcType="TINYINT" property="status" typeHandler="xxx.xxx.EnumTypeHandler" /> ... </resultMap>
而現在,我們可以不寫typeHandler了。
<resultMap> ... <result column="status" jdbcType="TINYINT" property="status" /> ... </resultMap>
以上就是本文的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持億速云!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。