1.使用注解的方式定义SQL语句:
Controller层:
java
@RequestMapping("/emps")
@Slf4j
@RestController
public class EmpController {
@Autowired
private EmpService empService;
//根据ID修改员工数据
@PutMapping()
public Result update(@RequestBody Emp emp){
log.info("修改员工数据:{}", emp);
empService.update(emp);
return Result.success();
}
}
Service接口层:
java
public interface EmpService {
/**
* 修改员工数据
*/
void update(Emp emp);
}
Service接口实现层:
java
@Service
public class EmpServiceImpl implements EmpService{
@Autowired
private EmpMapper empMapper;
@Override
public void update(Emp emp) {
empMapper.update(emp.getUsername(), emp.getName(), emp.getGender(), emp.getImage(), emp.getId(), LocalDateTime.now());
}
}
Mapper接口层:
java
@Mapper
public interface EmpMapper {
/**
* 根据ID修改员工数据
*/
@Update("update emp set username = #{username},name = #{name},gender=#{gender},update_Time=#{updateTime} ,image=#{image} where id=#{id}")
void update(String username, String name, Short gender, String image, Integer id, LocalDateTime updateTime);
}
2.使用Mybatis映射文件xml的方式:
Controller层(相同):
java
@RequestMapping("/emps")
@Slf4j
@RestController
public class EmpController {
@Autowired
private EmpService empService;
//根据ID修改员工数据
@PutMapping()
public Result update(@RequestBody Emp emp){
log.info("修改员工数据:{}", emp);
empService.update(emp);
return Result.success();
}
}
java
public interface EmpService {
/**
* 修改员工数据
*/
void update(Emp emp);
}
Service接口实现类:
java
@Service
public class EmpServiceImpl implements EmpService{
@Autowired
private EmpMapper empMapper;
//使用映射文件xml
@Override
public void update(Emp emp){
emp.setUpdateTime(LocalDateTime.now());
empMapper.update(emp);
}
}
Mapper层:
java
@Mapper
public interface EmpMapper {
//使用映射文件xml的方式
void update(Emp emp);
}
Mapper映射文件xml:
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.itheima.mapper.EmpMapper">
<!-- 更新员工数据-->
<update id="update">
update emp
<set>
<if test="username != null and username != ''">
username = #{username},
</if>
<if test="password!=null and passwprd !=''">
password = #{passwprd},
</if>
<if test="name!=null and name!=''">
name =#{name},
</if>
<if test="gender!=null">
gender=#{gender},
</if>
<if test="image !=null and image !=''">
image =#{image},
</if>
<if test="job!=null">
job=#{job},
</if>
<if test="entrydate!=null">
entrydate=#{entrydate},
</if>
<if test="deptId!=null">
dept_id=#{deptId},
</if>
<if test="updateTime!=null">
update_time =#{updateTime}
</if>
</set>
where id=#{id}
</update>
</mapper>
Mapper映射文件xml的路径要求如下:
- 放在项目的resources目录下。
- 在resources目录下创建一个与mapper接口全名相同的包名,例如:com.example.mapper。
- 在创建的包名目录下,创建一个与mapper接口同名的文件,例如:UserMapper.xml。
- 将mapper映射文件中的内容按照MyBatis的语法编写。