溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

mybatis?TypeHandler注入spring依賴的方法是什么

發(fā)布時間:2022-02-01 08:47:19 來源:億速云 閱讀:255 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要講解了“mybatis TypeHandler注入spring依賴的方法是什么”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“mybatis TypeHandler注入spring依賴的方法是什么”吧!

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想通過寫一個自定義的handler實現(xiàn)業(yè)務(wù)功能,該handler默認創(chuàng)建的時候,是不在spring的管理范圍里的,所以你在handler用@Autowired注入,是會報npe。

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

mybatis擴展:自定義TypeHandler

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

1、編寫自定義TypeHandler

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

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

對只進行處理就行了,每個方法都必須返回值,如果沒有返回的話,默認是不返回任何東西的,導(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)//需要替代的默認的JDBC類型,泛型類型String說明替代String類型
public class VarcharTypeHandler extends BaseTypeHandler<String> {
    /**
     * 對設(shè)置的值進行處理
     * @param preparedStatement
     * @param i
     * @param s
     * @param jdbcType
     * @throws SQLException
     */
    @Override
    public void setNonNullParameter(PreparedStatement preparedStatement, int i, String s, JdbcType jdbcType) throws SQLException {
        //我在傳進來的字符串后面加了一串字符串
        preparedStatement.setString(i,s+">>>>>>>>>>>>>>>>");
    }
    /**
     * 對獲取值的操作進行擴展,列名方式
     * @param resultSet
     * @param s
     * @return
     * @throws SQLException
     */
    @Override
    public String getNullableResult(ResultSet resultSet, String s) throws SQLException {
        return resultSet.getString(s);
    }
    /**
     * 對獲取值的操作進行擴展,索引方式
     * @param resultSet
     * @param i
     * @return
     * @throws SQLException
     */
    @Override
    public String getNullableResult(ResultSet resultSet, int i) throws SQLException {
        return resultSet.getString(i);
    }
    /**
     * 對其他獲取值的操作進行擴展
     * @param callableStatement
     * @param i
     * @return
     * @throws SQLException
     */
    @Override
    public String getNullableResult(CallableStatement callableStatement, int i) throws SQLException {
        return callableStatement.getString(i);
    }
}

2、配置TypeHandler

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

第一種配置方式

	@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),對username字段進行處理-->
  </insert>

3、測試

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
    /**
     * 測試insert方法
     */
    public void insertUser(){
        User user = new User();
        user.setUsername("zhangsan");
        user.setPassword("123456");
        userMapper.insert(user);
    }
    @Test
    /**
     * 測試selectAll方法
     */
    public void selectAllUser(){
        userMapper.selectAll().forEach(new Consumer<User>() {
            public void accept(User i) {
                //打印用戶名和密碼
                System.out.println(i.getUsername() +" ======> "+i.getPassword());
            }
        });
    }
}

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

mybatis?TypeHandler注入spring依賴的方法是什么

感謝各位的閱讀,以上就是“mybatis TypeHandler注入spring依賴的方法是什么”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對mybatis TypeHandler注入spring依賴的方法是什么這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI