MyBatis能够非常灵活地实现动态SQL
,可以使用XML或注解来配置和映射原生信息,能够轻松地将Java的POJO(Plain Ordinary Java Object,普通的Java对象)与数据库中的表和字段进行映射关联。
MyBatis-Plus是一个 MyBatis 的增强工具,在 MyBatis 的基础上做了增强,简化了开发。
添加依赖
<!-- 链接数据库 -->
<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";
}
}
添加依赖,创建实体类都是一样的。
创建Mapper,只需要直接继承BaseMapper
,便可拥有一些基础的操作。
@Mapper
public interface UserMapper extends BaseMapper<User> {}
@TableName,当表名与实体类名称不一致时,可以使用@TableName注解进行关联。 @TableField,当表中字段名称与实体类属性不一致时,使用@TableField进行关联 @TableId,用于标记表中的主键字段,MybatisPlus也提供了主键生成策略