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

mybatis TypeHandler注入spring的依賴方式

 更新時(shí)間:2022年01月28日 11:54:18   作者:Star--Zhang  
這篇文章主要介紹了mybatis TypeHandler注入spring的依賴方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

TypeHandler注入spring的依賴

解決方法

<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
? ? ? ? <!-- .... -->
? ? ? ? <property name="typeHandlers">
? ? ? ? ? <array>
? ? ? ? ? ? <bean class="com.example.YurCustomTypeHandler">
? ? ? ? ? ? ? <property name="property" ref="bean"/>
? ? ? ? ? ? </bean>
? ? ? ? ? </array>
? ? ? ? </property>
? ? </bean>

在mybatis想通過寫一個(gè)自定義的handler實(shí)現(xiàn)業(yè)務(wù)功能,該handler默認(rèn)創(chuàng)建的時(shí)候,是不在spring的管理范圍里的,所以你在handler用@Autowired注入,是會(huì)報(bào)npe。

需要通過上面的方式,就可以解決了。

mybatis擴(kuò)展:自定義TypeHandler

在Mybatis中定義了很多默認(rèn)的類型處理器,將sql語句中的值轉(zhuǎn)化成JDBC的類型,以及將結(jié)果集中的值轉(zhuǎn)化為字段類型的值,詳情可見官網(wǎng)默認(rèn)的TypeHandler,但是有的時(shí)候我們并不想用官網(wǎng)的TypeHandler的時(shí)候,自定義的TypeHandler就派上用場(chǎng)了

1、編寫自定義TypeHandler

在自定義的類上加上@MappedJdbcTypes(JdbcType.VARCHAR)注解,括號(hào)里的JdbcType.Varchar是需要替代的

默認(rèn)的JDBC類型,然后讓這個(gè)類繼承BaseHandler<String>,泛型類型String說明替代String類型,然后再重寫的方法中

對(duì)只進(jìn)行處理就行了,每個(gè)方法都必須返回值,如果沒有返回的話,默認(rèn)是不返回任何東西的,導(dǎo)致的結(jié)果就是,插入的值為null,獲得的值也全部為null

package javaDIYFree.typeHandler;
import org.apache.ibatis.type.BaseTypeHandler;
import org.apache.ibatis.type.JdbcType;
import org.apache.ibatis.type.MappedJdbcTypes;
import sun.security.provider.MD5;
import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
/**
 * @author Hearts
 * @date 2019/4/17
 * @desc
 */
@MappedJdbcTypes(JdbcType.VARCHAR)//需要替代的默認(rèn)的JDBC類型,泛型類型String說明替代String類型
public class VarcharTypeHandler extends BaseTypeHandler<String> {
    /**
     * 對(duì)設(shè)置的值進(jìn)行處理
     * @param preparedStatement
     * @param i
     * @param s
     * @param jdbcType
     * @throws SQLException
     */
    @Override
    public void setNonNullParameter(PreparedStatement preparedStatement, int i, String s, JdbcType jdbcType) throws SQLException {
        //我在傳進(jìn)來的字符串后面加了一串字符串
        preparedStatement.setString(i,s+">>>>>>>>>>>>>>>>");
    }
    /**
     * 對(duì)獲取值的操作進(jìn)行擴(kuò)展,列名方式
     * @param resultSet
     * @param s
     * @return
     * @throws SQLException
     */
    @Override
    public String getNullableResult(ResultSet resultSet, String s) throws SQLException {
        return resultSet.getString(s);
    }
    /**
     * 對(duì)獲取值的操作進(jìn)行擴(kuò)展,索引方式
     * @param resultSet
     * @param i
     * @return
     * @throws SQLException
     */
    @Override
    public String getNullableResult(ResultSet resultSet, int i) throws SQLException {
        return resultSet.getString(i);
    }
    /**
     * 對(duì)其他獲取值的操作進(jìn)行擴(kuò)展
     * @param callableStatement
     * @param i
     * @return
     * @throws SQLException
     */
    @Override
    public String getNullableResult(CallableStatement callableStatement, int i) throws SQLException {
        return callableStatement.getString(i);
    }
}

2、配置TypeHandler

有兩種方式配置,一種就是直接,再配置SqlSessionFactoryBean的時(shí)候,將自定義的TypeHandler配置進(jìn)去,但是這種方式不常用,應(yīng)為這就代表所有的Varchar的操作都是用自定義的TypeHandler了,一般我們只需要在某一個(gè)表的某一個(gè)字段進(jìn)行自定義,這個(gè)時(shí)候就用第二種方式配置了

第一種配置方式

	@Bean
    public SqlSessionFactoryBean createSqlSessionFactoryBean(DruidDataSource druidDataSource){
        final SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean();
        try{
            //配置數(shù)據(jù)源
            sqlSessionFactoryBean.setDataSource(druidDataSource);
            //配置mapper文件所在的位置
            sqlSessionFactoryBean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath:mapper/*.xml"));
            //配置自定義TypeHandler
            sqlSessionFactoryBean.setTypeHandlers(new TypeHandler[]{new VarcharTypeHandler()});
        } catch (IOException e) {
            e.printStackTrace();
        }
        return sqlSessionFactoryBean;
    }

在需要使用的操作和字段中添加typeHandler

? <insert id="insert" parameterType="javaDIYFree.model.User">
? ? insert into user (id, create_date, `name`,?
? ? ? did, `password`, username
? ? ? )
? ? values (#{id,jdbcType=BIGINT}, #{createDate,jdbcType=TIMESTAMP}, #{name,jdbcType=VARCHAR},?
? ? ? #{did,jdbcType=BIGINT}, #{password,jdbcType=VARCHAR}, #{username,jdbcType=VARCHAR,typeHandler=varcharTypeHandler}
? ? ? )
? ? ? <!--在插入操作內(nèi),對(duì)username字段進(jìn)行處理-->
? </insert>

3、測(cè)試

package javaDIYFree.dao;
import javaDIYFree.config.MybatisConfig;
import javaDIYFree.model.User;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import java.util.function.Consumer;
/**
 * @author Hearts
 * @date 2019/4/17
 * @desc
 */
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(classes = MybatisConfig.class)
public class UserMapperTest {
    @Autowired
    private UserMapper userMapper;
    @Test
    /**
     * 測(cè)試insert方法
     */
    public void insertUser(){
        User user = new User();
        user.setUsername("zhangsan");
        user.setPassword("123456");
        userMapper.insert(user);
    }
    @Test
    /**
     * 測(cè)試selectAll方法
     */
    public void selectAllUser(){
        userMapper.selectAll().forEach(new Consumer<User>() {
            public void accept(User i) {
                //打印用戶名和密碼
                System.out.println(i.getUsername() +" ======> "+i.getPassword());
            }
        });
    }
}

4、項(xiàng)目結(jié)構(gòu)圖

在這里插入圖片描述

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Spark學(xué)習(xí)筆記 (二)Spark2.3 HA集群的分布式安裝圖文詳解

    Spark學(xué)習(xí)筆記 (二)Spark2.3 HA集群的分布式安裝圖文詳解

    這篇文章主要介紹了Spark2.3 HA集群的分布式安裝,結(jié)合圖文與實(shí)例形式詳細(xì)分析了Spark2.3 HA集群分布式安裝具體下載、安裝、配置、啟動(dòng)及執(zhí)行spark程序等相關(guān)操作技巧,需要的朋友可以參考下
    2020-02-02
  • 基于Java實(shí)現(xiàn)Socket編程入門

    基于Java實(shí)現(xiàn)Socket編程入門

    Java最初是作為網(wǎng)絡(luò)編程語言出現(xiàn)的,使得客戶端和服務(wù)器的溝通變成了現(xiàn)實(shí),而在網(wǎng)絡(luò)編程中,使用最多的就是Socket,本文就來介紹一下基于Java實(shí)現(xiàn)Socket編程入門,感興趣的可以來了解一下
    2022-03-03
  • socket編程時(shí)的發(fā)送與接收數(shù)據(jù)時(shí)的問題解析

    socket編程時(shí)的發(fā)送與接收數(shù)據(jù)時(shí)的問題解析

    這篇文章主要為大家介紹了socket編程時(shí)的發(fā)送與接收數(shù)據(jù)時(shí)的問題解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • spring定時(shí)任務(wù)執(zhí)行兩次及tomcat部署緩慢問題的解決方法

    spring定時(shí)任務(wù)執(zhí)行兩次及tomcat部署緩慢問題的解決方法

    這篇文章主要給大家介紹了關(guān)于spring定時(shí)任務(wù)執(zhí)行兩次及tomcat部署緩慢問題的解決方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-01-01
  • Java基礎(chǔ)之讓你徹底搞懂代理模式

    Java基礎(chǔ)之讓你徹底搞懂代理模式

    這篇文章主要介紹了Java基礎(chǔ)之讓你徹底搞懂代理模式,文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)java基礎(chǔ)的小伙伴們有非常好的幫助,需要的朋友可以參考下
    2021-04-04
  • 使用springboot activiti關(guān)閉驗(yàn)證自動(dòng)部署方式

    使用springboot activiti關(guān)閉驗(yàn)證自動(dòng)部署方式

    這篇文章主要介紹了使用springboot activiti關(guān)閉驗(yàn)證自動(dòng)部署方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • IDEA?2021.3?使用及idea2021.3.1激活使用方法

    IDEA?2021.3?使用及idea2021.3.1激活使用方法

    IDEA?全稱?IntelliJ?IDEA,是java語言開發(fā)的集成環(huán)境,IntelliJ在業(yè)界被公認(rèn)為最好的java開發(fā)工具之一,今天通過本文給大家介紹idea2021.3.1激活及使用教程,感興趣的朋友一起看看吧
    2022-01-01
  • Java Redis Template批量查詢指定鍵值對(duì)的實(shí)現(xiàn)

    Java Redis Template批量查詢指定鍵值對(duì)的實(shí)現(xiàn)

    本文主要介紹了Java Redis Template批量查詢指定鍵值對(duì)的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • Java 創(chuàng)建PDF打印小冊(cè)子案例

    Java 創(chuàng)建PDF打印小冊(cè)子案例

    這篇文章主要給大家分享Java 創(chuàng)建PDF打印小冊(cè)子案例,PDF打印小冊(cè)子是指將PDF格式文檔在打印成刊物前需要提前進(jìn)行的頁面排版,以便在打印后裝訂成冊(cè),下面文章內(nèi)容我們將下面以Java代碼展示如何來實(shí)現(xiàn),需要的朋友可以參考一下
    2021-10-10
  • 如何在Spring?Boot框架中使用攔截器實(shí)現(xiàn)URL限制

    如何在Spring?Boot框架中使用攔截器實(shí)現(xiàn)URL限制

    在Spring?Boot框架中,您可以使用攔截器(Interceptor)來控制限制URL列表,本文通過一個(gè)簡(jiǎn)單的示例給大家介紹Spring?Boot?攔截器實(shí)現(xiàn)URL限制的操作方法,感興趣的朋友跟隨小編一起看看吧
    2023-08-08

最新評(píng)論