ホームページ >Java >&#&チュートリアル >springboot がユーザー名検索機能を実装する方法

springboot がユーザー名検索機能を実装する方法

王林
王林転載
2023-05-13 08:58:051270ブラウズ

ユーザー名に基づいてユーザーをクエリする機能を実装するには、Spring Boot フレームワークでいくつかのクラスを記述する必要があります:

1. UserEnetity クラス

これはエンティティ クラスです。データベース テーブルに基づいて、ユーザーの基本情報をカプセル化するために使用されます。このテーブルでは、ユーザー関連の属性を定義し、ゲッター メソッドとセッター メソッドを提供する必要があります。

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;
    }
}

2. UserMapper クラス

これは MyBatis に基づくインターフェイスで、ユーザーのクエリ、ユーザーの追加、ユーザーの更新などのデータベース操作のメソッドを定義するために使用されます。

@Mapper
public interface UserMapper extends BaseMapper {
    List<UserEntity> findAllUser();
 
    UserDTO getUserByUsername(String subject);
}

3. UserService クラス

ビジネス ロジック層であり、主に 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("查询失败,该用户不存在"));
        }
    }

4. UserController クラス

これは、ユーザー要求を処理し、対応する結果を返すために使用されるコントローラー層です。このクラスでは、ユーザー名に基づいてユーザーをクエリし、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);
    }

要するに、これら 4 つのクラスを作成する必要があり、それらの間の関係も設計する必要があります。このうち、User Entity クラスと UserMapper クラスはデータベースと密接な関係があり、UserService クラスはビジネス ロジック層の核となり、UserController クラスはコントローラー層の核となり、ユーザーのリクエストを処理して応答を返す役割を果たします。結果。

5.郵便配達員のテスト結果

springboot がユーザー名検索機能を実装する方法

以上がspringboot がユーザー名検索機能を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はyisu.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。