@mapper注解的使用_三分钟让你看懂Springboot 中 Mybatis 的使用
时间: 2024-03-22 19:38:02 浏览: 119
好的,@Mapper注解是Mybatis框架中用于标识数据访问层接口的注解,用于告诉Spring容器将该接口类实例化并注入到其他Bean中。其使用步骤如下:
1. 在Spring Boot项目中引入Mybatis和Mybatis-Spring的依赖
2. 在配置文件中配置数据源和Mybatis的相关属性
3. 创建一个数据访问层接口,使用@Mapper注解标识该接口
4. 在该数据访问层接口中定义需要操作的数据库方法
5. 在Service或Controller中注入该数据访问层接口的实例,并调用其中的方法
下面是一个示例:
1. 在pom.xml中添加Mybatis和Mybatis-Spring的依赖:
```xml
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.4.6</version>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.1.1</version>
</dependency>
```
2. 在application.properties中配置数据源和Mybatis的相关属性:
```properties
spring.datasource.url=jdbc:mysql://localhost:3306/test
spring.datasource.username=root
spring.datasource.password=123456
mybatis.type-aliases-package=com.example.demo.entity
mybatis.mapper-locations=classpath:mapper/*.xml
```
3. 创建一个数据访问层接口UserMapper,使用@Mapper注解标识该接口:
```java
@Mapper
public interface UserMapper {
User selectByPrimaryKey(Integer id);
int insert(User record);
int updateByPrimaryKey(User record);
int deleteByPrimaryKey(Integer id);
}
```
4. 在mapper目录下创建UserMapper.xml,定义需要操作的数据库方法:
```xml
<mapper namespace="com.example.demo.mapper.UserMapper">
<resultMap id="BaseResultMap" type="com.example.demo.entity.User">
<id column="id" property="id" jdbcType="INTEGER"/>
<result column="username" property="username" jdbcType="VARCHAR"/>
<result column="password" property="password" jdbcType="VARCHAR"/>
</resultMap>
<select id="selectByPrimaryKey" resultMap="BaseResultMap" parameterType="java.lang.Integer">
select *
from user
where id = #{id,jdbcType=INTEGER}
</select>
<insert id="insert" parameterType="com.example.demo.entity.User" useGeneratedKeys="true" keyProperty="id">
insert into user (username, password)
values (#{username,jdbcType=VARCHAR}, #{password,jdbcType=VARCHAR})
</insert>
<update id="updateByPrimaryKey" parameterType="com.example.demo.entity.User">
update user
set username = #{username,jdbcType=VARCHAR},
password = #{password,jdbcType=VARCHAR}
where id = #{id,jdbcType=INTEGER}
</update>
<delete id="deleteByPrimaryKey" parameterType="java.lang.Integer">
delete from user
where id = #{id,jdbcType=INTEGER}
</delete>
</mapper>
```
5. 在Service或Controller中注入UserMapper的实例,并调用其中的方法:
```java
@Service
public class UserServiceImpl implements UserService {
@Autowired
private UserMapper userMapper;
@Override
public User selectByPrimaryKey(Integer id) {
return userMapper.selectByPrimaryKey(id);
}
@Override
public int insert(User user) {
return userMapper.insert(user);
}
@Override
public int updateByPrimaryKey(User user) {
return userMapper.updateByPrimaryKey(user);
}
@Override
public int deleteByPrimaryKey(Integer id) {
return userMapper.deleteByPrimaryKey(id);
}
}
```
这就是使用@Mapper注解的基本步骤,希望对你有所帮助。
阅读全文