為了實現根據使用者名稱查詢使用者功能,我們需要在spring boot框架當中編寫幾個類別:
它是根據資料庫表的實體類,用於封裝使用者的基本資訊。在這個表當中,需要定義與使用者相關的屬性,並提供getter和setter方法。
public class UserEntity { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private int id; private String name; public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } private String username; private int role; private String avatar; private int status; private String password; public UserEntity(int id, String name, int role, String avatar, int status, String password,String username,String token) { this.id = id; this.name = name; this.role = role; this.avatar = avatar; this.status = status; this.password = password; this.username = username; } public UserEntity() { } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getRole() { return role; } public void setRole(int role) { this.role = role; } public String getAvatar() { return avatar; } public void setAvatar(String avatar) { this.avatar = avatar; } public int getStatus() { return status; } public void setStatus(int status) { this.status = status; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } }
它是基於MyBatis的接口,用於定義資料庫操作的方法,例如查詢使用者、新增使用者、更新使用者等。
@Mapper public interface UserMapper extends BaseMapper { List<UserEntity> findAllUser(); UserDTO getUserByUsername(String subject); }
它是業務邏輯層,主要負責協調UserMapper類別和User Entity類別之間的關係,實現業務邏輯的處理。在這個類別中,需要定義根據使用者名稱查詢使用者的方法,並呼叫UserMapper類別的方法實作查詢操作。
//用户名查询用户 public ResultResponse findByUsername(String name) { QueryWrapper<UserEntity> queryWrapper = new QueryWrapper<>(); queryWrapper.eq("name", name); UserEntity user = (UserEntity) userMapper.selectOne(queryWrapper); if (user != null) { return ResultResponse.returnToken(ResultResponse.success("查询成功", user)); } else { return ResultResponse.returnToken(ResultResponse.fail("查询失败,该用户不存在")); } }
它是控制器層,用於處理使用者請求,傳回對應的結果。在這個類別中,需要定義請求處理方法,例如根據使用者名稱查詢使用者的方法,以及傳回JSON格式的資料。
//根据用户名查询用户--查询结果分每页十条显示 @GetMapping("user/findByUsername") public ResultResponse<IPage<UserEntity>> findByUsername(@RequestParam String username, @RequestParam Integer pageNumber, @RequestParam Integer pageSize) { Page<UserEntity> userPage = new Page<>(pageNumber, pageSize); // IPage<UserEntity> user = (IPage<UserEntity>) userService.selectByUsername(userPage, username); UserEntity user = userService.selectByUsername(userPage,username); if (user == null) { return ResultResponse.error("没有找到匹配的用户"); } return ResultResponse.ok("查询成功",user); }
總之,這四個類別都是需要寫的,而且它們之間的關係也需要設計好。其中,User Entity類別與UserMapper類別與資料庫之間的關係較緊密,UserService類別則是作為業務邏輯層的核心,而UserController類別則是作為控制器層的核心,負責處理使用者請求和回傳回應結果。
以上是springboot如何實現使用者名稱查找使用者功能的詳細內容。更多資訊請關注PHP中文網其他相關文章!