spring boot 2.x 集成 mybatis

引入关于mybatis的starter

compile 'org.mybatis.spring.boot:mybatis-spring-boot-starter:1.3.2'

spring boot 配置文件中的mybatis配置项

#######mybatis配置######
###配置xml映射文件通用位置
mybatis.mapper-locations=classpath:mybatis/mappers/*.xml
###扫描别名包和@alias联用
mybatis.type-aliases-package=com.primerxiao.springboot.chapter5.pojo
###配置typehandler的扫描包
mybatis.type-handlers-package=com.primerxiao.springboot.chapter5.typehandler
#######mybatis配置######

创建实体类以及操作接口

import com.primerxiao.springboot.chapter5.enumeration.SexEnum;
import lombok.Data;
import org.apache.ibatis.type.Alias;

@Data
@Alias(value = "user")
public class User {
    private long id;
    private String userName;
    private SexEnum sex;
    private String note;
}
import com.primerxiao.springboot.chapter5.pojo.User;
import org.springframework.stereotype.Repository;

@Repository
public interface UserDao {
    public User getUser(long id);
}

创建typehandler转换性别

import com.primerxiao.springboot.chapter5.enumeration.SexEnum;
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 java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

@MappedJdbcTypes(JdbcType.INTEGER)
@MappedTypes(value = SexEnum.class)
public class SexTypeHandler extends BaseTypeHandler<SexEnum> {
    @Override
    public void setNonNullParameter(PreparedStatement ps, int i, SexEnum parameter, JdbcType jdbcType) throws SQLException {
        ps.setInt(i,parameter.getId());
    }

    @Override
    public SexEnum getNullableResult(ResultSet rs, String columnName) throws SQLException {
        int sexId = rs.getInt(columnName);
        if (sexId!=1&&sexId!=2) {
            return null;
        }
        return SexEnum.getEnumById(sexId);
    }

    @Override
    public SexEnum getNullableResult(ResultSet rs, int columnIndex) throws SQLException {

        int sexId = rs.getInt(columnIndex);
        if (sexId!=1&&sexId!=2) {
            return null;
        }
        return SexEnum.getEnumById(sexId);
    }

    @Override
    public SexEnum getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {
        int sexId = cs.getInt(columnIndex);
        if (sexId!=1&&sexId!=2) {
            return null;
        }
        return SexEnum.getEnumById(sexId);
    }
}

创建用户映射文件(userMapper.xml)

<?xml version="1.0" encoding="utf-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD MAPPER 3.0//EN"
        "http://mybatis.org/dtd/schema/mybatis-3-mapper.dtd">
<mapper namespace="com.primerxiao.springboot.chapter5.dao.UserDao">
    <select id="getUser" parameterType="long" resultType="user">
        select id,user_name as userName,sex,note from t_user where id=#{id}
    </select>
</mapper>

定义mybatis操作接口(dao)

import com.primerxiao.springboot.chapter5.pojo.User;
import org.springframework.stereotype.Repository;

@Repository
public interface UserDao {
    public User getUser(long id);
}

使用控制器测试mybatis接口

import com.primerxiao.springboot.chapter5.dao.UserDao;
import com.primerxiao.springboot.chapter5.pojo.User;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;


@RestController
@RequestMapping("/user")
public class UserController {

    @Autowired
    private UserDao userDao;


    @RequestMapping("/getUser")
    public User getUser(Long id) {

        User user = userDao.getUser(id);
        return user;
    }

}

装配mybatis接口(用@MapperScan定义扫描)

@SpringBootApplication(scanBasePackages = {"com.primerxiao.springboot.chapter5"})
@EnableJpaRepositories(basePackages = "com.primerxiao.springboot.chapter5.dao")
@EntityScan(basePackages = "com.primerxiao.springboot.chapter5.pojo")
@MapperScan(
        basePackages = "com.primerxiao.springboot.chapter5.*",
        sqlSessionFactoryRef = "sqlSessionFactory",
        sqlSessionTemplateRef = "sqlSessionTemplate",
        annotationClass = Repository.class
)
public class Chapter5Application implements ApplicationContextAware  {


    @Autowired
    public static   ApplicationContext context;


    public static void main(String[] args) {
        SpringApplication.run(Chapter5Application.class, args);

    }

    @Override
    public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {

        Chapter5Application.context=applicationContext;
    }
}

启动项目后通过intellij idea自带的httpclient工具测试,附上测试结果

HTTP/1.1 200 
Content-Type: application/json;charset=UTF-8
Transfer-Encoding: chunked
Date: Wed, 23 Jan 2019 03:59:56 GMT

{
  "id": 1,
  "userName": "1",
  "sex": "MAIL",
  "note": "1"
}

Response code: 200; Time: 327ms; Content length: 47 bytes

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值