Mybatis在sqlite中無法讀寫byte[]類問題的解決辦法
開發(fā)環(huán)境: springboot + mybatis plus
場(chǎng)景:在DAO的bean中有byte[]類時(shí),寫入可以成功,但是讀取不行。從錯(cuò)誤棧中可以看到原因是:sqlite的driver中,JDBC4ResultSet沒有實(shí)現(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)會(huì)選擇第3個(gè)接口。因此,這里只需要將處理方法切換到前兩個(gè)接口即可:方法就是更換一個(gè)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)鍵點(diǎn):
添加@TableName(autoResultMap = true) 添加@TableField(typeHandler = ByteArrayTypeHandler.class)之后就可以正常讀寫byte[]了
總結(jié)
到此這篇關(guān)于Mybatis在sqlite中無法讀寫byte[]類問題的文章就介紹到這了,更多相關(guān)Mybatis在sqlite無法讀寫byte[]類內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. MySQL為Null會(huì)導(dǎo)致5個(gè)問題(個(gè)個(gè)致命)2. MySQL Truncate用法詳解3. sql2000下 分頁(yè)存儲(chǔ)過程4. 傳 Oracle 欲 收購(gòu)金蝶?5. 局域網(wǎng)內(nèi)的ado 連接 sql server6. 深入分析MySQL數(shù)據(jù)類型 DECIMAL7. Access 模糊參數(shù) 分頁(yè)查詢8. SQLite教程(一):SQLite數(shù)據(jù)庫(kù)介紹9. Oracle創(chuàng)建用戶與表空間的絕對(duì)干貨(建議收藏)10. MySQL8.0無法啟動(dòng)3534的解決方法
