mysql 模糊查询 查询条件为多个

模糊查询 查询条件为2个

一般写模糊查询。我们通过用一个字段用于模糊查询也就是 name Like CONCAT(’%, #{name}, ‘%’) ,这样比较简单 但是如果条件为两个或多个怎么办? 我们一步步来。以下是一个完整的例子
有一张表book 里面有两个字段 如book_name 和 author 我们现在根据这两个字段模糊查询

// 我们遵从mvc模式
// dao 层
// BookMapper.java 
    /**
     * @Title: listLikeBookNameOrAuthor
     * @Description: 根据书名或者作者模糊查询
     * @param bookName
     * @param author
     * @return: list
     * @throws
     * @author: zyy
     * @Date:  2021/2/22  14:02
     */
    List<Book> listLikeBookNameOrAuthor(String bookName, String author);

// serive接口
// IBookService.java
    /**
     * @Title: search
     * @Description: 根据书名或者作者模糊查询
     * @param searchText
     * @return: list
     * @throws
     * @author: zyy
     * @Date:  2021/2/22  14:04
     */
    List<BookResponseVO> search(String searchText);

// impl实现类
// BookServiceImpl.java 实现service接口
  @Override
    public List<BookResponseVO> search(String searchText) {
    
    
        return bookMapper.listLikeBookNameOrAuthor(searchText, searchText);
    }

// controller层
// BookController
    @GetMapping("/api/search/{searchText}")
    public List<BookResponseVO> search(@PathVariable("searchText") String searchText) {
    
    
        return bookService.search(searchText);
    }

需要注意的是,我在service层里面 只有一个参数,在dao层有两个参数,这是因为我们在进行查询的时候,只通过一个输入框输入需要查询的内容 ,这个查询内容可以是book_name 或者 author 都可以。

以下是BookMapper.xml
delete_flag 是一个删除标志。。为0表示未删除

       SELECT 
        book_name
        author
        FROM  book b
        WHERE b.book_name LIKE CONCAT('%',#{
    
    bookName},'%')
        OR b.author LIKE CONCAT('%',#{
    
    author},'%')
        AND delete_flag=0

猜你喜欢

转载自blog.csdn.net/qq_41831842/article/details/113939619