springboot mybaits

Springboot + mybaits

mybatis-spring-boot-starter主要有两种解决方案,一种是使用注解解决一切问题,一种是简化后的老传统。
无配置文件注解版,就是一切使用注解搞定。这里先介绍无配置文件注解版

一、无配置文件注解版

1、引入依赖

<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>2.1.0</version>
</dependency>

<!-- mysql驱动-->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <scope>runtime</scope>
</dependency>

2、配置文件application.properties

mybatis.type-aliases-package=com.example.demo
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/test?serverTimezone=UTC
spring.datasource.username=root
spring.datasource.password=123456

springboot会自动加载spring.datasource.*相关配置,数据源就会自动注入到sqlSessionFactory中,sqlSessionFactory会自动注入到Mapper中,对了你一切都不用管了,直接拿起来使用就行了。

3、添加java代码

在启动类中添加对mapper包扫描@MapperScan
或者直接在Mapper类上面添加注解@Mapper,建议使用上面那种,不然每个mapper加个注解也挺麻烦的

package com.example.demo;

import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
@MapperScan("com.example.demo") //添加扫描包
public class DemoApplication {

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

User.java

package com.example.demo;

import java.io.Serializable;

public class User implements Serializable {
    private static final long serialVersionUID = 1L;

    private int id;
    private String name;
    private int age;

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

    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;
    }

    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", age=" + age +
                '}';
    }
}

开发Mapper UserMapper.java

package com.example.demo;

import org.apache.ibatis.annotations.Insert;

public interface UserMapper {

    @Insert("INSERT INTO user(id,name,age) VALUES(#{id}, #{name}, #{age})")
    void insert(User user);
}

HelloController.java

package com.example.demo;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;

import java.util.List;
import java.util.Map;

//@RestController //RestController = Controller + ResponseBody
@Controller
public class HelloController {

    private final static Logger logger= LoggerFactory.getLogger(HelloController.class); 

    @Autowired
    private UserMapper userMapper; 

    @RequestMapping("/add")
    @ResponseBody
    public String save() {
        logger.info("---------save()--------------");
        User user = new User(3, "cm", 18);
        userMapper.insert(user);
        return "ok";
    }
}

访问http://localhost:8080/add 

 

二、xml配置版 

极简xml版本保持映射文件的老传统,优化主要体现在不需要实现dao的是实现层,系统会自动根据方法名在映射文件中找对应的sql.

pom文件和上个版本一样,只是application.properties新增以下配置

mybatis.config-locations=classpath:mybatis/mybatis-config.xml
mybatis.mapper-locations=classpath:mybatis/mapper/*.xml

指定了mybatis基础配置文件和实体类映射文件的地址
mybatis-config.xml 配置

<configuration>
    <typeAliases>
        <typeAlias alias="Integer" type="java.lang.Integer" />
        <typeAlias alias="Long" type="java.lang.Long" />
        <typeAlias alias="HashMap" type="java.util.HashMap" />
        <typeAlias alias="LinkedHashMap" type="java.util.LinkedHashMap" />
        <typeAlias alias="ArrayList" type="java.util.ArrayList" />
        <typeAlias alias="LinkedList" type="java.util.LinkedList" />
    </typeAliases>
</configuration>

添加User的映射文件UserMapper.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.example.demo.UserMapper">

    <insert id="insert" parameterType="com.example.demo.User">
       INSERT INTO user (id,name,age) VALUES (#{id}, #{name}, #{age})
    </insert>
</mapper>

其实就是把上个版本中mapper的sql搬到了这里的xml中了

package com.example.demo;

public interface UserMapper {

    void insert(User user);
}

两种模式各有特点,注解版适合简单快速的模式,其实像现在流行的这种微服务模式,一个微服务就会对应一个自已的数据库,多表连接查询的需求会大大的降低,会越来越适合这种模式。
老传统模式比适合大型项目,可以灵活的动态生成SQL,方便调整SQL,也有痛痛快快,洋洋洒洒的写SQL的感觉。

参考网址:https://blog.csdn.net/gebitan505/article/details/54929287 

 

Q:Idea的spring工程里,经常会遇到Could not autowire. No beans of 'xxxx' type found的错误提示。
但程序的编译和运行都是没有问题的,这个错误提示并不会产生影响。
原因: spring auto scan配置,在编辑情况下,无法找不到对应的bean,于是提示找不到对应bean的错误。
解决方案:降低Autowired检测的级别,将Severity的级别由之前的error改成warning或其它可以忽略的级别。
Settings=>Editor=>inspections=>spring=>spring core=> code=>Autowiring for Bean Class=> Error改成warning

 

posted @ 2019-09-25 16:37  牧 天  阅读(137)  评论(0)    收藏  举报