美文网首页
spring-boot接入mybatis

spring-boot接入mybatis

作者: Poseidon_Wang | 来源:发表于2017-06-21 09:52 被阅读191次

    mybatis接入spring-boot

    开发环境为idea,spring-boot项目,前期的准备就跳过了

    pom.xml配置
    <dependency>
        <groupId>org.mybatis.spring.boot</groupId>
        <artifactId>mybatis-spring-boot-starter</artifactId>
        <version>1.3.0</version>
    </dependency>
    
    首先是注解方式
    application.yml配置

    此处已配置完数据库

    spring:
      profiles:
        active: dev
      datasource:
        username: root
        password: 123456
        driver-class-name: com.mysql.jdbc.Driver
        url: jdbc:mysql://127.0.0.1:3306/test
      jpa:
        hibernate:
          ddl-auto: update
        show-sql: true
    
    首先注册dao的接口

    首先贴出bean

    @Entity
    public class Person {
        @Id
        @GeneratedValue
        private int id;
        private String name;
        @Min(value=10,message = "too young")
        private int age;
        public Person(){
    
        }
    
        public int getId() {
            return id;
        }
    
        public void setId(int id) {
            this.id = id;
        }
    
        public String getName() {
            return name;
        }
    
        public void setName(String name) {
            this.name = name;
        }
    
        public int getAge() {
            return age;
        }
    
        public void setAge(int age) {
            this.age = age;
        }
    }
    

    接下来是dao类

    @Component
    @Mapper
    public interface PersonAnnotationDao {
        @Select("SELECT * FROM person")
        List<Person> findAll();
    }
    

    这里只是简单的做了一个查询方法

    最后我们进行junit test

    具体的spring 单元测试请自行搜索

       @Autowired
        private PersonAnnotationDao personAnnotationDao;
    
    
        @Test
        public void testMyBatisFindAllPersons() {
            Assert.assertEquals(1, personMapper.findAllPersons().size());
        }
    

    这里可以调试调取具体的数据

    接下来看看xml方式的调用
    application.yml配置

    此处已配置完数据库

    mybatis:
    mapper-locations: classpath:mybatis/mapper/*.xml
    type-aliases-package: com.leo.domain
    config-location: classpath:mybatis/mybatis-config.xml
    

    注意路径resources的子目录为第一级目录

    配置mybatis-config.xml
    <settings>
    <setting name="cacheEnabled" value="true"/>
    <setting name="lazyLoadingEnabled" value="true"/>
    <setting name="multipleResultSetsEnabled" value="true"/>
    <setting name="useColumnLabel" value="true"/>
    <setting name="useGeneratedKeys" value="false"/>
    <setting name="autoMappingBehavior" value="PARTIAL"/>
    <setting name="autoMappingUnknownColumnBehavior" value="WARNING"/>
    <setting name="defaultExecutorType" value="SIMPLE"/>
    <setting name="defaultStatementTimeout" value="25"/>
    <setting name="defaultFetchSize" value="100"/>
    <setting name="safeRowBoundsEnabled" value="false"/>
    <setting name="mapUnderscoreToCamelCase" value="false"/>
    <setting name="localCacheScope" value="SESSION"/>
    <setting name="jdbcTypeForNull" value="OTHER"/>
    <setting name="lazyLoadTriggerMethods" value="equals,clone,hashCode,toString"/>
    </settings>
    

    相关属性及意义请参考官方文档

    创建mapper接口
    @Component
    @Mapper
    public interface PersonMapper {
        List<Person> findAllPersons();
    
        Person findById(int id);
    
        void insertPerson(int age,String name);
    
    }
    

    这@Component->注入到spring容器中,使用的时候就可以不手动初始化
    @Mapper->声明这是一个Mybatis的操作类,会被扫描到

    配置mapper.xml文件
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
            "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
    
    <mapper namespace="com.leo.mapper.PersonMapper">
    
        <resultMap id="person" type="Person">
            <id property="id" column="id"/>
            <result property="age" column="age"/>
            <result property="name" column="name"/>
        </resultMap>
        <select id="findAllPersons" resultType="Person">
            SELECT *
            FROM person
        </select>
        <select id="findById" resultType="Person">
            SELECT * FROM person WHERE id=#{id}
        </select>
        <insert id="insertPerson" keyProperty="id">
            insert into person(age,name) values(#{age},#{name})
        </insert>
    </mapper>
    

    文件头可复制
    mapper-namespace:与xml对应的java文件的全限定名
    resultMapr:一个封装的结构,可以组合复杂的返回类型提供下面的sql调用
    <select>节点:对应上面mapper类的查询方法
    <insert>,<update>...对应相应的sql方法
    select-id:对应mapper类内的方法名
    select-resultType:对用返回类型,注意这里没有集合类,可以用集合类的基本元素填入
    select-resultMap:返回类型即为上诉定义的复杂类型
    具体的完整属性介绍
    官方文档-mapper配置

    相关文章

      网友评论

          本文标题:spring-boot接入mybatis

          本文链接:https://www.haomeiwen.com/subject/nrawattx.html