要求:现在有user实体类,前端传name和password,后端判断是否存在这个用户,有返回true,没有返回fals
因为user中还有其他属性可以再建立一个实体类,作为接收数据的容器
@Data
public class UserDto {
String name;
String password;
}
在controller接收数据,并把这个业务交给serve层去完成
@PostMapping("/login")
public boolean login(@RequestBody UserDto userDto){
boolean login = userService.login(userDto);
return login;
}
serve接口中做方法的规范
public interface IUserService extends IService<User> {
boolean login(UserDto userDto);
}
serve层中实现登录功能,这里注意getOne的使用
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements IUserService {
@Override
public boolean login(UserDto userDto) {
QueryWrapper<User> wrapper = new QueryWrapper<>();
wrapper.eq("username",userDto.getName());
wrapper.eq("password",userDto.getPassword());
User one = getOne(wrapper);
if(one !=null){
return true;
}else {
return false;
}
}
}
使用getOne()方法:
在MyBatis-Plus中,getOne()
方法是BaseMapper接口提供的一个查询方法,用于查询符合条件的单条记录。
queryWrapper
:查询条件包装器,用于构建查询条件
例子:
Wrapper<User> wrapper = new QueryWrapper<User>().eq("username", "john");
User user = userMapper.getOne(wrapper);
上述示例中,我们通过eq()
方法设置了查询条件,筛选出username
等于"john"的用户记录。然后使用getOne()
方法根据查询条件查询单条记录。
需要注意的是,getOne()
方法的返回值是一个实体对象,如果查询结果符合条件的记录有多条,则只返回第一条。如果查询结果为空,getOne()
方法返回null。