這期內容當中小編將會給大家帶來有關如何在Mybatis中使用自定義類型轉換器,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
javabean如下:
public class User { private Integer id; private Message message; } public class Message { private Integer id; private String address; private String job; }
數據庫User表如下:
列名 | 類型 |
---|---|
id | int |
message | varchar |
Message對象在java中是一個bean,而在數據庫中是一個字符串,這中間需要類型轉換一下,所以我的目的是:
通過自定義類型轉換器,在存數據得到時候自動將message對象轉化為字符串類型,存入數據庫中。在取數據的時候,則自動將字符串轉化為Message對象封裝進結果集。
類型轉換器:
@MappedTypes(Message.class) @MappedJdbcTypes(JdbcType.VARCHAR) public class MessageTypeHandler implements TypeHandler<Message> { @Override public void setParameter(PreparedStatement ps, int i, Message parameter, JdbcType jdbcType) throws SQLException { ps.setString(i, JSON.toJSONString(parameter)); } @Override public Message getResult(ResultSet rs, String columnName) throws SQLException { return JSON.parseObject(rs.getString(columnName),Message.class); } @Override public Message getResult(ResultSet rs, int columnIndex) throws SQLException { return JSON.parseObject(rs.getString(columnIndex),Message.class); } @Override public Message getResult(CallableStatement cs, int columnIndex) throws SQLException { return null; } }
在mybatis配置文件中添加如下配置:
<typeHandlers> <typeHandler handler="org.mybatis.***.MessageTypeHandler"/> </typeHandlers>
這樣我們就可以直接編寫sql而不用手動去處理類型轉換的事情了。
<insert id="insertUser"> insert into user (id,message) values (#{id},#{message}) </insert> <select id="getUser" parameterType="int" resultType="org.mybatis.***.mapper.User" > select id,message from user where id = #{id} </select>
上述就是小編為大家分享的如何在Mybatis中使用自定義類型轉換器了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。