欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MyBatis?typeHandler接口的定義和使用

 更新時間:2023年05月17日 10:23:01   作者:shenzhenNBA  
TypeHandler被稱作類型處理器,MyBatis在設置預處理語句中的參數(shù)或從結果集中取出一個值時,都會用類型處理器將Java對象轉化為數(shù)據(jù)庫支持的類型或者將獲取到數(shù)據(jù)庫值以合適的方式轉換成Java類型,感興趣的同學可以參考下文

在Java項目中一般我們都需要處理數(shù)據(jù)庫表到Java的Bean對象的映射關系,常用的ORM框架有mybatis,在大多數(shù)據(jù)情況下,數(shù)據(jù)庫的數(shù)據(jù)類型到Java的數(shù)據(jù)類型滿足我們的需要,例如varchar到String,int到int等,但是有些時候項目需要完成數(shù)據(jù)庫數(shù)據(jù)類型到Java的某個數(shù)據(jù)類型的映射,mybatis現(xiàn)有的typeHandler不滿足要求,所以需要用戶自己開發(fā)用戶自定義的typeHandler類型,以滿足要求;

例如,數(shù)據(jù)庫需要保存用戶喜歡的產(chǎn)品,表字段以varchar類型保存,同時是一個符合JSON格式的列表,每個產(chǎn)品信息按 "產(chǎn)品名稱(產(chǎn)品代碼)",所以最終結果:["產(chǎn)品名稱1(產(chǎn)品代碼1)","產(chǎn)品名稱2(產(chǎn)品代碼2)"],即符合列表格式的JSON字符串,其對應的Java的Bean變量為一個字符型的List變量,即List<String>,所以需要完成數(shù)據(jù)庫表字段的Varchar數(shù)據(jù)類型到Java的List<String>的映射處理關系,現(xiàn)有的typeHandler類型不足以滿足要求,所以我們需要開發(fā)一個用戶自定義的mybatis的typeHandler來處理這個問題,然后應用到mapper的XML文件中,大致框架代碼(具體自行豐富補充)和步驟如下:

1,引入相關依賴Jar包,版本看自行根據(jù)需要定義

<!-- mybatis依賴 -->
<dependency>  
    <groupId>org.mybatis.spring.boot</groupId>  
    <artifactId>mybatis-spring-boot-starter</artifactId>  
    <version>2.0.0</version>  
</dependency>
<!-- 數(shù)據(jù)庫連接池 -->
<dependency>  
    <groupId>com.alibaba</groupId>  
    <artifactId>druid</artifactId>  
    <version>1.1.10</version>  
</dependency>
<!-- mysql數(shù)據(jù)庫連接 -->
<dependency>  
    <groupId>mysql</groupId>  
    <artifactId>mysql-connector-java</artifactId>  
    <version>5.1.48</version>
	<!--此僅參考,版本根據(jù)需要而定-->
</dependency>

2,用戶相關的JavaBean對象

package com.xx.yy.zz.model; 
import java.util.List;
public class UserProduct {
	private String userName;
	private String userCode
	//DB字段以JSON格式保存:["產(chǎn)品名1(產(chǎn)品代碼1)","產(chǎn)品名2(產(chǎn)品代碼2)",...]
	private List<String> likeProducts = new ArraryList<String>();
	//...other... 
	//...setter/getter省略...
}

3,自定義DB表字段(內容為符合JSON格式的字符串列表)的varchar數(shù)據(jù)類型到Java的List的映射處理關系的typeHandler開發(fā)

package com.xx.yy.zz.orm; 
import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.List;
import org.apache.ibatis.type.BaseTypeHandler;
import org.apache.ibatis.type.JdbcType;
import org.apache.ibatis.type.MappedJdbcTypes;
import org.apache.ibatis.type.MappedTypes;
import com.alibaba.fastjson.JSONObject; //需要fastjson的jar包支持
@MappedTypes(List.class) //映射的Java數(shù)據(jù)類型
@MappedJdbcTypes(JdbcType.VARCHAR)  //映射的JDBC數(shù)據(jù)類型
public class MyListTypeHandler extends BaseTypeHandler<List<String>>{
	//List列表中如果為其它對象xxJavaBean則把String換為目標對象	
	//重寫mybatis設置參數(shù)的方法
	@Override
	public void setNonNullParameter(PreparedStatement ps,int i, List<String> param,
		JdbcType jdbcType) throws SQLException {
		ps.setString(i, JSONObject.toJSONString(param));
	}
	//重寫mybatis獲取字段字符串型內容到Bean類List變量的方法
	@Override
	public List<String> getNullableResult(ResultSet rs, String columnName)
		throws SQLException{
		String tempJson = rs.getString(columnName);
		if (null != tempJson && !tempJson.trim().isEmpty()){
			return JSONObject.parseArray(tempJson,String.class);
		}
		return null;
	}
	@Override
	public List<String> getNullableResult(ResultSet rs, int columnIndex)
		throws SQLException{
		String tempJson = rs.getString(columnIndex);
		if (null != tempJson && !tempJson.trim().isEmpty()){
			return JSONObject.parseArray(tempJson,String.class);
		}
		return null;
	}
	@Override
	public List<String> getNullableResult(CallableStatement cs, int columnIndex)
		throws SQLException{
		String tempJson = cs.getString(columnName);
		if (null != tempJson && !tempJson.trim().isEmpty()){
			return JSONObject.parseArray(tempJson,String.class);
		}
		return null;
	}
}

4, 操作數(shù)據(jù)庫的DAO層定義

package com.xx.yy.zz.dao;
import com.xx.yy.zz.model.UserProduct;
public interface UserProductDao {
	int insertRecord(UserProduct record);
	int updateRecord(UserProduct record);
	//...more code...
}

5,在springboot的配置yml文件中進行mybatis相關配置

#其它配置項省略

mybatis:

mapper-locations: classpath:mapper/*Mapper.xml

type-aliases-package: com.xx.yy.zz.model

6,在Mapper的XML文件中應用自定義的typeHandler類型,部分代碼如下

<mapper namespace="com.xx.yy.zz.dao.UserProductDao" >
	<resultMap id="resultMap" type="com.xx.yy.zz.model.Product">
		<id column="id" property="id" jdbcType="Decimal">
		<result column="likeProdcts" property="likeProdcts" jdbcType="varchar"
			typeHandler="com.xx.yy.zz.orm.MyListTypeHandler">
		<!-- ...other result... -->
	</resultMap>
</mapper>
<!-- 新增 -->
<insert id="insertRecord" parameterType="UserProduct">
	insert into xxTable
	<trim prefix="(" suffix=")" suffixOverride=",">
		<if test="userName != null">
		userName,
		</if>
		<!-- ...other... -->
		<if test="likeProdcts != null">
		likeProdcts,
		</if>		
	</trim>
	<trim prefix=" values (" suffix=")" suffixOverride=",">
		<if test="userName != null">
		#{userName,jdbcType=varchar},
		</if
		<!-- ...other... -->
		<if test="likeProdcts != null">
		#{likeProdcts,jdbcType=varchar,typeHandler=com.xx.yy.zz.orm.MyListTypeHandler},
		</if>
	</trim>
</insert>
<!-- 更新 -->
<update id="updateRecord" parameterType="UserProduct">
	update xxTable 
	<set>
		<if test="likeProdcts != null">
		#{likeProdcts,jdbcType=varchar,typeHandler=com.xx.yy.zz.orm.MyListTypeHandler},
		</if>
		<!-- ...other... -->
	</set>
	where id = #{id,jdbcType=decimal}
</update>

這樣處理之后即可滿足,數(shù)據(jù)庫表字段數(shù)據(jù)類型為varchar類型,字段保存內容為符合JSON格式的字符串,到JavaBean對象為List<String>列表類型的映射和處理,從Java持久化到表字段時自動轉化為符合JSON格式的內容保存,另一方面,程序從DB表字段內容讀取到Java程序時內容自動轉化為List<String>,非常方便,另外數(shù)組類型String[]也可以,但是Java對數(shù)組的增刪等操作,不如 List 方便,所以推薦使用 List 比較好,當然,本例List中列表的項為String類型,那如果為某個JavaBean對象呢?其實完全可以,方法類似的,這里為簡單舉例就用String,本身String也是一個對象;

除了我們自定義的 MyListTypeHandler 類型外,其mybatis本身內部已經(jīng)含有很多的typeHandler類型,例如:BooleanTypeHandler,ByteTypeHandler,ShortTypeHandler,IntegerTypeHandler,LongTypeHandler,F(xiàn)loatTypeHandler,DoubleTypeHandler,StringTypeHandler,ClobTypeHandler,DateTypeHandler等等這些其實就是默認已經(jīng)在為我們處理完成映射關系了,只不過內部已經(jīng)有,且直接內部自動完成映射,我們不需要顯示指定typeHandler而已,這就是mybatis框架的功能,已經(jīng)幫我們完成了絕大部分功能,我們僅需處理一下特別的或特定需要即可;

到此這篇關于MyBatis typeHandler接口的定義和使用的文章就介紹到這了,更多相關MyBatis typeHandler內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 實例講解Java中的synchronized

    實例講解Java中的synchronized

    這篇文章主要介紹了Java中synchronized的使用方法,文中講解非常細致,代碼幫助大家更好的理解和學習,感興趣的朋友可以了解下
    2020-07-07
  • 詳解通過JDBC進行簡單的增刪改查(以MySQL為例)

    詳解通過JDBC進行簡單的增刪改查(以MySQL為例)

    JDBC是用于執(zhí)行SQL語句的一類Java API,通過JDBC使得我們可以直接使用Java編程來對關系數(shù)據(jù)庫進行操作。通過封裝,可以使開發(fā)人員使用純Java API完成SQL的執(zhí)行。
    2017-01-01
  • MyBatis-Plus解決邏輯刪除與唯一索引的問題

    MyBatis-Plus解決邏輯刪除與唯一索引的問題

    本文主要介紹了MyBatis-Plus解決邏輯刪除與唯一索引的問題,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-08-08
  • JavaMail實現(xiàn)帶附件的郵件發(fā)送

    JavaMail實現(xiàn)帶附件的郵件發(fā)送

    這篇文章主要為大家詳細介紹了JavaMail實現(xiàn)帶附件的郵件發(fā)送,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • java讀取txt文件內容簡單舉例

    java讀取txt文件內容簡單舉例

    這篇文章主要給大家介紹了關于java讀取txt文件內容簡單舉例的相關資料,通常我們可以直接通過文件流來讀取txt文件的內容,文中給出了詳細的代碼示例,需要的朋友可以參考下
    2023-07-07
  • 緩存工具類ACache使用方法詳解

    緩存工具類ACache使用方法詳解

    這篇文章主要為大家詳細介紹了緩存工具類ACache的使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-08-08
  • 如何實現(xiàn)Spring?Event(異步事件)

    如何實現(xiàn)Spring?Event(異步事件)

    這篇文章主要介紹了如何實現(xiàn)Spring?Event(異步事件)問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • Java內存區(qū)域管理詳解

    Java內存區(qū)域管理詳解

    這篇文章主要介紹了Java內存區(qū)域管理詳解,文章通過圍繞主題展開詳細的內容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-09-09
  • Graphics2D 寫圖片中文亂碼問題及解決

    Graphics2D 寫圖片中文亂碼問題及解決

    這篇文章主要介紹了Graphics2D 寫圖片中文亂碼問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • Java?8中的Collectors?API介紹

    Java?8中的Collectors?API介紹

    這篇文章主要介紹了Java?8中的Collectors?API,Stream.collect()是Java?8的流API的終端方法之一。它允許我們對流實例中保存的數(shù)據(jù)元素執(zhí)行可變折疊操作,下文相關內容需要的小伙伴可以參考一下
    2022-04-04

最新評論