十年網站開發(fā)經驗 + 多家企業(yè)客戶 + 靠譜的建站團隊
量身定制 + 運營維護+專業(yè)推廣+無憂售后,網站問題一站解決
這期內容當中小編將會給大家?guī)碛嘘P怎么在Mybatis中通過自定義TypeHandler解決特殊類型轉換問題,文章內容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
創(chuàng)新互聯(lián)公司基于成都重慶香港及美國等地區(qū)分布式IDC機房數(shù)據(jù)中心構建的電信大帶寬,聯(lián)通大帶寬,移動大帶寬,多線BGP大帶寬租用,是為眾多客戶提供專業(yè)四川移動機房托管報價,主機托管價格性價比高,為金融證券行業(yè)服務器托管,ai人工智能服務器托管提供bgp線路100M獨享,G口帶寬及機柜租用的專業(yè)成都idc公司。
定義一個role類,與數(shù)據(jù)庫的role表對應:
public class Role { private Integer id; private String name; private Integer[] accessIds; private Date createTime; // ... ignore get and set methods }
注意到里面有一個accessIds字段,它的類型是Integer[]
數(shù)據(jù)庫設計:
DROP TABLE IF EXISTS `role`; CREATE TABLE `role` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(255) NOT NULL, `access_ids` varchar(255) DEFAULT NULL, `create_time` datetime NOT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8; -- ---------------------------- -- Records of role -- ---------------------------- INSERT INTO `role` VALUES ('1', '測試角色', ',1,2,', '2019-11-14 13:43:14');
自定義Handler類
通過繼承BaseTypeHandler類,重寫其方法,定義一個Integer[]與數(shù)據(jù)庫varchar類型自動轉換的Handler類:
/** * Java Int數(shù)組與MySQL String轉換器 * 比如[1,2,3] --> ",1,2,3," */ public class StringToIntArrayHandler extends BaseTypeHandler{ private static final String splitCharset = ","; @Override public void setNonNullParameter(PreparedStatement ps, int i, Integer[] objects, JdbcType jdbcType) throws SQLException { String str = arrayToString(objects); ps.setString(i, str); } @Override public Integer[] getNullableResult(ResultSet rs, String columnName) throws SQLException { String str = rs.getString(columnName); return stringToArray(str); } @Override public Integer[] getNullableResult(ResultSet rs, int columnIndex) throws SQLException { String str = rs.getString(columnIndex); return stringToArray(str); } @Override public Integer[] getNullableResult(CallableStatement cs, int columnIndex) throws SQLException { String str = cs.getString(columnIndex); return stringToArray(str); } // --- private methods --- /** * Integer數(shù)組轉String * 注:使用提前設定好的分隔符分割數(shù)組的每一項 */ private static String arrayToString(Integer[] array) { StringBuilder res = new StringBuilder(); if (array != null && array.length > 0) { for (Object o : array) { res.append(splitCharset).append(o.toString()); } res.append(splitCharset); } return res.length() > 0 ? res.toString() : null; } /** * 從String轉Integer數(shù)組 * 注:String是用分隔符分割的,使用String.split方法可以分解為數(shù)組 */ private static Integer[] stringToArray(String str) { List list = new ArrayList<>(); if (str != null) { String[] array = str.split(splitCharset); if (array.length > 0) { for (String o : array) { if (o != null && o.length() > 0) { list.add(Integer.parseInt(o)); } } } } return list.toArray(new Integer[0]); } }
這個類的具體作用是什么呢?
當Java中類型是Integer[]時,使用這個Handler類,將Integer[]轉換為以,號分割的字符串,然后存入數(shù)據(jù)庫
當從數(shù)據(jù)庫讀取以,分割值的字符串時,可以通過這個Handler,自動將字符串轉換為Integer[]數(shù)組
下面我們演示一下具體的使用smile
在Mybatis中應用自定義的Handler
Mybatis存放SQL語句的XML文件:
SELECT LAST_INSERT_ID() INSERT INTO role (name, create_time, access_ids) VALUES (#{name}, #{createTime} , #{accessIds, jdbcType=VARCHAR, typeHandler=com.example.model.dao.handler.StringToIntArrayHandler})
上述就是小編為大家分享的怎么在Mybatis中通過自定義TypeHandler解決特殊類型轉換問題了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。