MyBatis能够非常灵活地实现动态SQL,可以使用XML或注解来配置和映射原生信息,能够轻松地将Java的POJO(Plain Ordinary Java Object,普通的Java对象)与数据库中的表和字段进行映射关联。

MyBatis-Plus是一个 MyBatis 的增强工具,在 MyBatis 的基础上做了增强,简化了开发。

Untitled

Mybits使用

添加依赖

<!-- 链接数据库 -->
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.4.2</version>
</dependency>
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>5.1.47</version>
</dependency>
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid-spring-boot-starter</artifactId>
    <version>1.1.20</version>
</dependency>

application.properties中配置据库数链接信息:

spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/spring??AllowPublicKeyRetrieval=True
spring.datasource.username=root
spring.datasource.password=root
mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl

创建User实体类,一定要有Getter,Setter方法。

创建Mapper接口,实现动态SQL。

@Mapper
public interface UserMapper {
    @Select("select * from t_user")
    public List<User> find();
}

最后在路由中调用

@RestController
public class mapper {
    @Autowired
    UserMapper userMapper;

    @GetMapping("/m1")
    public String m1(){
        List<User> users = userMapper.find();
        System.out.println(users);
        return "yes";
    }
}

MybitsPlugs使用

添加依赖,创建实体类都是一样的。

创建Mapper,只需要直接继承BaseMapper,便可拥有一些基础的操作。

@Mapper
public interface UserMapper extends BaseMapper<User> {}

@TableName,当表名与实体类名称不一致时,可以使用@TableName注解进行关联。 @TableField,当表中字段名称与实体类属性不一致时,使用@TableField进行关联 @TableId,用于标记表中的主键字段,MybatisPlus也提供了主键生成策略