SpringBoot:4.SpringBoot整合Mybatis实现数据库访问

在公司项目开发中,使用Mybatis居多。在 SpringBoot:3.SpringBoot使用Spring-data-jpa实现数据库访问 中,这种jpa风格的把sql语句和java代码放到一起,总感觉分离的不够彻底。基于个人习惯,还是比较喜欢把代码和sql分开,sql语句在xml文件里不管多复杂,写到xml里看起来比较简单,不是那么臃肿。

1.整合Mybatis

1.1 添加pom.xml依赖

主要就四个依赖:

spring-boot-starter-test、spring-boot-starter:用于做单元测试

mybatis-spring-boot-starter:Mybatis核心依赖

mysql-connector-java:Mysql依赖,访问数据库

        
            org.springframework.boot
            spring-boot-starter
         
        
            org.springframework.boot
            spring-boot-starter-test
            test
        
        
            org.mybatis.spring.boot
            mybatis-spring-boot-starter
            1.1.1
        
        
        
            mysql
            mysql-connector-java
            5.1.21
                            

1.2 配置数据库信息

在application.properties 配置相关mysql信息

#数据库配置
spring.datasource.url=jdbc:mysql://localhost:3306/test
spring.datasource.username=root
spring.datasource.password=123456
spring.datasource.driver-class-name=com.mysql.jdbc.Driver

#mybatis放置xml文件的地方,我们配置在classpath下的mapper文件夹下
mybatis.mapper-locations=classpath*:mapper/*.xml

1.3 创建user表

通过下面的sql语句创建user表信息:包括id、name(名字)、age(年龄)。

DROP TABLE IF EXISTS `user`;
CREATE TABLE `user` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) DEFAULT NULL,
  `age` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=latin1;

1.4 创建实体类

创建user表的映射实体类。

package com.w3cjava.entity;
public class User {
    private Long id;

    private String name;

    private Integer age;

    public User() {
    }

    public User(String name, int age) {
        this.name = name;
        this.age = age;
    }

    public Long getId() {
        return id;
    }

    public void setId(Long id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }   
}

1.5 数据访问层Dao

创建User实体类的UserDao层,实现简单的增删改查操作。

package com.w3cjava.dao;

import java.util.List;
import java.util.Map;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import com.w3cjava.entity.User;

@Mapper
public interface UserDao{
    int insert(@Param("name") String name, @Param("age") Integer age);

    /**
     * 
     * @author cos
     * @desc 通过Map对象来作为传递参数的容器
     * @param map
     * @return
     */
    int insertByMap(Map map);
    /**
     * 
     * @author cos
     * @desc 使用对象
     * @param user
     * @return
     */
    
    int insert(User user);
    
    void update(User user);

    void delete(Long id);
    /**
     * 
     * @author cos
     * @desc 返回结果的绑定
     * @return
     */
    List findAll();    
    /**
     * 
     * @author cos
     * @desc 使用@Param传参,@Param中定义的name对应了SQL中的#{name},age对应了SQL中的#{age}
     * @param name
     * @return
     */
    User findByName(@Param("name") String name);
}

1.6 数据访问xml映射

通过mybatis.mapper-locations=classpath:mapper/.xml配置,我们将在classpath路径的mapper文件夹下创建UserDao对应的映射xml。




    
        a.id AS "id",
        a.name AS "name",
        a.age AS "age"
    
    
    
    
    
       
     
    
            
         
    
        INSERT INTO user(
            name,
            age
        ) VALUES (
            #{name},
            #{age}
            )
    
    
    
        INSERT INTO user(
            name,
            age
        ) VALUES (
            #{name,jdbcType=VARCHAR},
            #{age,jdbcType=INTEGER}
            )
    
    
        UPDATE user SET age=#{age} WHERE name=#{name}
    
    
        DELETE FROM user WHERE id =#{id}
        

2.应用启动类

创建应用主类。@EnableTransactionManagement之所以加上这个注解,是为了后面每一个单元测试时使用回顾注解,保证数据库数据测试完成后不被污染。以便开始下一个测试。

package com.w3cjava;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.transaction.annotation.EnableTransactionManagement;
/**
 * 
 * @class  SpringBootMybatisApplication
 * @version SpringBoot 2.1.9
 * @author cos
 * @desc   整合Mybatis
 *
 */
@SpringBootApplication
@EnableTransactionManagement
public class SpringBootMybatisApplication {
    public static void main(String[] args) {
        SpringApplication.run(SpringBootMybatisApplication.class, args);
    }

}

3.单元测试

测试基本逻辑:

  • 向数据库中插入数据
  • 查询部分数据
  • 通过使用@Rollback、@Transactional回滚数据,保证每一次单元测试数据的独立性。
@RunWith(SpringRunner.class)
@SpringBootTest(classes = {SpringBootMybatisApplication.class})
public class UserServiceTest {
    @Autowired
    private UserDao userDao;
    @Test
    @Transactional
    @Rollback
    public void insert() throws Exception {
        userDao.insert("AAA", 20);
    }
    
    @Test
    @Transactional
    @Rollback
    public void findByName() throws Exception {
        userDao.insert("AAA", 20);
        User u = userDao.findByName("AAA");
        Assert.assertEquals(20, u.getAge().intValue());
    }
    
    @Test
    @Transactional
    @Rollback
    public void testMap() throws Exception{
        Map map = new HashMap<>();
        map.put("name", "CCC");
        map.put("age", 40);
        userDao.insertByMap(map);
    }
    
    
    @Test
    @Transactional
    @Rollback
    public void testuserDao() throws Exception {
        // insert一条数据,并select出来验证
        userDao.insert("AAA", 20);
        User u = userDao.findByName("AAA");
        Assert.assertEquals(20, u.getAge().intValue());
        // update一条数据,并select出来验证
        u.setAge(30);
        userDao.update(u);
        u = userDao.findByName("AAA");
        Assert.assertEquals(30, u.getAge().intValue());
        // 删除这条数据,并select验证
        userDao.delete(u.getId());
        u = userDao.findByName("AAA");
        Assert.assertEquals(null, u);
    }
    
    
    @Test
    @Transactional
    @Rollback
    public void testSelectMapper() throws Exception {
        List userList = userDao.findAll();
        for(User user : userList) {
            Assert.assertEquals(null, user.getId());
            Assert.assertNotEquals(null, user.getName());
        }
    }
}

4.参考文章

spring-test @Rollback回滚: https://www.jianshu.com/p/3b2...

5.文章源码

04.Spring-Boot-Mybatis
欢迎扫面下列二维码关注“余弦的自留地”公众微信号
在这里插入图片描述
万物之中,希望至美

你可能感兴趣的:(mybatis)