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. MySQL5.7 mysqldump備份與恢復(fù)的實(shí)現(xiàn)2. 快速解決mysql導(dǎo)出scv文件亂碼、躥行的問題3. html中select語句讀取mysql表中內(nèi)容4. MySQL InnoDB架構(gòu)的相關(guān)總結(jié)5. MySql使用mysqldump 導(dǎo)入與導(dǎo)出方法總結(jié)6. Mysql InnoDB和MyISAM區(qū)別原理解析7. SqlServer 多種分頁方式 詳解(含簡(jiǎn)單速度測(cè)試)8. MySQL 數(shù)據(jù)丟失排查案例9. SQLite3 命令行操作指南10. Mybatis傳入List實(shí)現(xiàn)批量更新的示例代碼
