欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Bean?Searcher配合SpringBoot的使用詳解

 更新時間:2022年06月02日 14:06:01   作者:m0_54861649  
這篇文章主要介紹了Bean?Searcher配合SpringBoot的使用,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

先吐槽一下,現(xiàn)在的Bean Searcher操作手冊的指引弱的可憐…
對我這樣的小白及其不友好

話不多說直入主題

1、首先肯定是得引入依賴

<dependency>
            <groupId>com.ejlchina</groupId>
            <artifactId>bean-searcher-boot-starter</artifactId>
            <version>${searcher.version}</version>
        </dependency>

2、再配置一下設置

bean-searcher:
  params:
    pagination:
      start: 1

其他的依賴、數(shù)據(jù)源啥的比較常用這里就不展出

3、然后就是創(chuàng)建實體類

由于我為了快速就用了之前使用MyBatis做持久化的一個項目,所以會有Mapper啥的,不過看官方文檔和Demo上的例子,好像也沒用到所以應該沒影響

!??!為了直觀我直接Copy源代碼上來,可以先跳過這個源碼直接看重點介紹

package com.so2.core.model.entity;
import com.baomidou.mybatisplus.annotation.*;
import java.io.Serializable;
import java.util.Date;
import com.ejlchina.searcher.bean.BeanAware;
import com.ejlchina.searcher.bean.DbField;
import com.ejlchina.searcher.bean.SearchBean;
import lombok.Data;
/**
 1. 用戶表
 2. @author Lynn
 3. @TableName user
 */
@TableName(value ="user")
@Data
@SearchBean( tables = "user")
public class User implements Serializable, BeanAware {
    /**
     * 
     */
    @TableId(type = IdType.AUTO)
    @DbField("id")
    private Integer id;
    /**
     * 用戶名
     */
    @DbField("name")
    private String name;
    /**
     * 用戶 id
     */
    @DbField("userId")
    private Integer userid;
    /**
     * 用戶郵箱
     */
    @DbField("email")
    private String email;
    /**
     * 用戶密碼
     */
    @DbField("password")
    private String password;
    /**
     * 用戶是否被封禁, 0-未封禁,1-已封禁
     */
    @DbField
    private Byte delflag;
    /**
     * 用戶權限, 0-游客, 1-普通用戶, 2-會員用戶, 3-管理員
     */
    @DbField("role")
    private Byte role;
    /**
     * 注冊日期
     */
    @DbField("registerTime")
    private Date registertime;
    @Override
    public boolean equals(Object that) {
        if (this == that) {
            return true;
        }
        if (that == null) {
            return false;
        }
        if (getClass() != that.getClass()) {
            return false;
        }
        User other = (User) that;
        return (this.getId() == null ? other.getId() == null : this.getId().equals(other.getId()))
            && (this.getName() == null ? other.getName() == null : this.getName().equals(other.getName()))
            && (this.getUserid() == null ? other.getUserid() == null : this.getUserid().equals(other.getUserid()))
            && (this.getEmail() == null ? other.getEmail() == null : this.getEmail().equals(other.getEmail()))
            && (this.getPassword() == null ? other.getPassword() == null : this.getPassword().equals(other.getPassword()))
            && (this.getDelflag() == null ? other.getDelflag() == null : this.getDelflag().equals(other.getDelflag()))
            && (this.getRole() == null ? other.getRole() == null : this.getRole().equals(other.getRole()))
            && (this.getRegistertime() == null ? other.getRegistertime() == null : this.getRegistertime().equals(other.getRegistertime()));
    }
    @Override
    public int hashCode() {
        final int prime = 31;
        int result = 1;
        result = prime * result + ((getId() == null) ? 0 : getId().hashCode());
        result = prime * result + ((getName() == null) ? 0 : getName().hashCode());
        result = prime * result + ((getUserid() == null) ? 0 : getUserid().hashCode());
        result = prime * result + ((getEmail() == null) ? 0 : getEmail().hashCode());
        result = prime * result + ((getPassword() == null) ? 0 : getPassword().hashCode());
        result = prime * result + ((getDelflag() == null) ? 0 : getDelflag().hashCode());
        result = prime * result + ((getRole() == null) ? 0 : getRole().hashCode());
        result = prime * result + ((getRegistertime() == null) ? 0 : getRegistertime().hashCode());
        return result;
    }
    @Override
    public String toString() {
        StringBuilder sb = new StringBuilder();
        sb.append(getClass().getSimpleName());
        sb.append(" [");
        sb.append("Hash = ").append(hashCode());
        sb.append(", id=").append(id);
        sb.append(", name=").append(name);
        sb.append(", userid=").append(userid);
        sb.append(", email=").append(email);
        sb.append(", password=").append(password);
        sb.append(", delflag=").append(delflag);
        sb.append(", role=").append(role);
        sb.append(", registertime=").append(registertime);
        sb.append("]");
        return sb.toString();
    }
    @Override
    public void afterAssembly() {
        System.out.println("--------使用了afterAssembly方法----------");
    }
}

創(chuàng)建實體類需要注意幾點

  1. 類,要在類名加上 @SearchBean( tables = “定義表名”) 注解,而且必須加上表名,我之前不加表名會報錯,而且加上表名在進行多表查詢時才能復用
  2. 實現(xiàn)接口,必須要實現(xiàn) BeanAware或者ParamAware接口,重寫的方法可以不做任何改動。
  3. 字段,必須要在需要得到響應的字段或查詢的字段上加上**@DbField(“自定義字段名”)** 注解,而且必須指定字段名,且加上注解的字段必須 大于0 | 大于被查詢數(shù)
  4. get set,加上LomBok的 @Data 注解,或使用idea的快速生成

4、最后就是編寫Controller層

先粘上源碼
同上,也可先跳過源碼直接看注意事項

package com.so2.core.controller;
import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.ejlchina.searcher.MapSearcher;
import com.ejlchina.searcher.SearchResult;
import com.ejlchina.searcher.Searcher;
import com.ejlchina.searcher.util.MapUtils;
import com.github.xiaoymin.knife4j.annotations.ApiSupport;
import com.so2.core.service.impl.UserServiceImpl;
import com.so2.core.model.entity.User;
import com.so2.core.base.BaseResponse;
import com.so2.core.base.ResultUtils;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiImplicitParam;
import io.swagger.annotations.ApiOperation;
import org.apache.catalina.util.RequestUtil;
import org.apache.ibatis.util.MapUtil;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;
import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
/**
 * 描述:測試類
 *
 * @author: Lynn
 * @date: 2021/12/3
 */
@Api(tags = "測試接口類")
@ApiSupport(author = "Lynn", order = 07)
@RestController
@RequestMapping("/test")
public class HealthController {
	//MyBatis
    @Resource
    private UserServiceImpl user;
	//注入MapSearcher
    @Autowired
    private MapSearcher mapSearcher;
//	先使用MyBatis方法做個對照組	
//	提示:BaseResponse是我寫的響應類,而ResultUtils是返回工具類,返回的結果包含了響應碼、響應數(shù)據(jù)、控制臺提示
//    千萬別加這個,一旦加了就會報空指針異常
//    @ApiImplicitParam(name = "userName", value = "用戶賬號名", required = true)
    @ApiOperation(value = "通過用戶賬號名獲取信息")
    @GetMapping("/getN")
    @ResponseBody
    public BaseResponse<List<User>> testGetUser(String userName){
        QueryWrapper<User> qw = new QueryWrapper<>();
        qw.like("name", userName);
        return ResultUtils.success(user.list(qw), "查找成功");
    }
//	這個方法比較多變,官方文檔也有說明
    @ApiOperation(value = "通過新的Searcher方法來進行便捷查找")
    @ResponseBody
    @GetMapping("/searcherGet")
    public Object getForSearcher(HttpServletRequest request){
		//	可以在builder()后使用其他方法進行數(shù)據(jù)篩選
        return mapSearcher.search(User.class,
                MapUtils.builder()
                        .build());
    }
//	這個方法可以傳入值進行動態(tài)查找
    @ApiOperation(value = "使用Searcher “動態(tài)“ 查找字段")
    @ResponseBody
    @GetMapping("/searcherGetName")
    public BaseResponse<Object> dynamicField(){
        Map<String, Object> map = new HashMap<>();
        map.put("name", "Lynn");
        return ResultUtils.success(mapSearcher.searchList(User.class, map), "------動態(tài)查詢字段成功------");
    }

}

Controller層編寫的注意事項

  1. 需要先注入MapSearcherBeanSearcher(官方文檔那個提示構建構造器的步驟坑死我了,還以為要寫一個單例Bean來進行配置)
  2. 看源碼注釋,哈哈
  3. (dog這個源碼比較粗糙,看的出來我并沒有對一些可能出現(xiàn)的異常、情況進行捕獲。

看看我查詢返回的數(shù)據(jù)

MyBatis查詢

Bean Searcher查詢

返回加了字段名字段的所有信息

查找字段名為name且值為Lynn的加了字段名字段的信息

結語

最后要說一句,現(xiàn)在網上的文章很多都是抄來抄去的,有互相抄的也有直接搬官方文檔的,所以大家在學一樣東西之前如果有官方文檔官方示例一定要先去看,別問我為什么懂這個道理的…

最后附上Bean Searcher官方文檔地址和示例的gitee倉庫

官方文檔地址: https://searcher.ejlchina.com/

官方Gitee倉庫地址:git@gitee.com:ejlchina-zhxu/bean-searcher.git

到此這篇關于Bean Searcher配合SpringBoot的使用的文章就介紹到這了,更多相關Bean Searcher配合SpringBoot使用內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Java中一維二維數(shù)組的靜態(tài)和動態(tài)初始化

    Java中一維二維數(shù)組的靜態(tài)和動態(tài)初始化

    今天通過本文給大家分享Java中的數(shù)組,包括一維數(shù)組和二維數(shù)組的靜態(tài)初始化和動態(tài)初始化問題,感興趣的朋友一起看看吧
    2017-10-10
  • Spring Cloud Zuul路由規(guī)則動態(tài)更新解析

    Spring Cloud Zuul路由規(guī)則動態(tài)更新解析

    這篇文章主要介紹了Spring Cloud Zuul路由規(guī)則動態(tài)更新解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-11-11
  • Spring security認證兩類用戶代碼實例

    Spring security認證兩類用戶代碼實例

    這篇文章主要介紹了Spring security認證兩類用戶代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-06-06
  • java執(zhí)行Linux命令的方法

    java執(zhí)行Linux命令的方法

    這篇文章主要介紹了java執(zhí)行Linux命令的方法,涉及對Java中Runtime.exec()函數(shù)的應用,具有一定的參考借鑒價值,需要的朋友可以參考下
    2014-11-11
  • 詳解Java的readBytes是怎么實現(xiàn)的

    詳解Java的readBytes是怎么實現(xiàn)的

    眾所周知,Java是一門跨平臺語言,針對不同的操作系統(tǒng)有不同的實現(xiàn),下面小編就來從一個非常簡單的api調用帶大家來看看Java具體是怎么做的吧
    2023-07-07
  • Java語言通過三種方法實現(xiàn)隊列的示例代碼

    Java語言通過三種方法實現(xiàn)隊列的示例代碼

    這篇文章主要介紹了Java語言通過三種方法來實現(xiàn)隊列的實例代碼,數(shù)組模擬隊列,通過對定義的了解,發(fā)現(xiàn)隊列很像我們的數(shù)組,下面我們通過實踐給大家詳細介紹,需要的朋友可以參考下
    2022-02-02
  • @RequestParam使用defaultValue屬性設置默認值的操作

    @RequestParam使用defaultValue屬性設置默認值的操作

    這篇文章主要介紹了@RequestParam使用defaultValue屬性設置默認值的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-02-02
  • 詳解Reactor中Context的用法

    詳解Reactor中Context的用法

    在Reactor中提供了Context來替代ThreadLocal,可以實現(xiàn)一個跨線程的共享變量的透明方式。本文主要為大家介紹了Context的用法的用法,感興趣的可以了解一下
    2023-02-02
  • Java SpringBoot高級用法詳解

    Java SpringBoot高級用法詳解

    這篇文章主要為大家詳細介紹了Java Spring Boot的一些高級用法,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-09-09
  • MyBatis-Plus 使用枚舉自動關聯(lián)注入

    MyBatis-Plus 使用枚舉自動關聯(lián)注入

    本文主要介紹了MyBatis-Plus 使用枚舉自動關聯(lián)注入,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-06-06

最新評論