Mybatis在sqlite中無法讀寫byte[]類問題的解決辦法
開發(fā)環(huán)境: springboot + mybatis plus
場景:在DAO的bean中有byte[]類時,寫入可以成功,但是讀取不行。從錯誤棧中可以看到原因是:sqlite的driver中,JDBC4ResultSet沒有實現(xiàn)以下接口:
public Blob getBlob(int col) throws SQLException { throw unused(); } public Blob getBlob(String col) throws SQLException { throw unused(); }
讀寫byte[]在JDBC規(guī)范中有3種接口:
InputStream getBinaryStream(int col) byte[] getBytes(int col) Blob getBlob(int col)Mybatis Plus默認(rèn)會選擇第3個接口。因此,這里只需要將處理方法切換到前兩個接口即可:方法就是更換一個TypeHandler
直接上代碼:
@Data@TableName(autoResultMap = true)public class Member { @TableId private String personId; private String name; private String telephone; @TableField(typeHandler = ByteArrayTypeHandler.class) private byte[] img; private String ext; private Integer type; private Integer ts;}
關(guān)鍵點:
添加@TableName(autoResultMap = true) 添加@TableField(typeHandler = ByteArrayTypeHandler.class)之后就可以正常讀寫byte[]了
總結(jié)
到此這篇關(guān)于Mybatis在sqlite中無法讀寫byte[]類問題的文章就介紹到這了,更多相關(guān)Mybatis在sqlite無法讀寫byte[]類內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. MySQL分區(qū)的優(yōu)點2. 分析MongoDB和MySQL各自的關(guān)鍵特性、差別和優(yōu)勢3. MySQL 字符串函數(shù):字符串截取4. Oracle與MySQL刪除字段時對索引和約束的處理5. 使用XQuery查詢DB2 XML數(shù)據(jù)6. 如何用mysqldump進(jìn)行全量和時間點備份7. mysql數(shù)據(jù)庫中最常用的時間轉(zhuǎn)換函數(shù)的用法8. MySQL創(chuàng)始人發(fā)郵件尋求中國幫助9. MySQL 中行轉(zhuǎn)列的方法10. Access字符串處理函數(shù)整理
