中文亚洲精品无码_熟女乱子伦免费_人人超碰人人爱国产_亚洲熟妇女综合网

當(dāng)前位置: 首頁 > news >正文

甘肅網(wǎng)站建設(shè)開發(fā)百度大搜推廣開戶

甘肅網(wǎng)站建設(shè)開發(fā),百度大搜推廣開戶,西安網(wǎng)站推廣公司,dnf免做卡網(wǎng)站本文已收錄于專欄 《Java》 目錄 背景介紹概念說明單字段模糊匹配:多字段模糊匹配: 實現(xiàn)過程代碼實現(xiàn)1.寫一個實體類去實現(xiàn)Specification接口,重寫toPredicate方法2.定義一個接口去繼承JpaRepository接口,并指定返回的類型和參數(shù)類…
本文已收錄于專欄
《Java》

目錄

  • 背景介紹
  • 概念說明
    • 單字段模糊匹配:
    • 多字段模糊匹配:
  • 實現(xiàn)過程
    • 代碼實現(xiàn)
      • 1.寫一個實體類去實現(xiàn)Specification接口,重寫toPredicate方法
      • 2.定義一個接口去繼承JpaRepository接口,并指定返回的類型和參數(shù)類型
      • 3.在業(yè)務(wù)類中調(diào)用聲明的接口
      • 4.在Controller中直接調(diào)用業(yè)務(wù)類中的方法即可
    • 執(zhí)行結(jié)果
  • 其他方式
    • 1.使用JPQL進(jìn)行模糊查詢:
    • 2.使用Spring Data JPA的Query By Example進(jìn)行模糊查詢:
    • 3.使用Spring Data JPA的@Query注解進(jìn)行模糊查詢:
  • 總結(jié)提升

背景介紹

??在我們的項目中很多的業(yè)務(wù)都會設(shè)計模糊查詢,例如按照姓氏去獲取人員的信息,按照手機(jī)號的前三位去獲取人員的信息等。我們除了正常的手寫模糊查詢的sql語句去獲取信息之外,還可以使用JPA自帶的API來實現(xiàn)任意字段的模糊查詢。JPA已經(jīng)給我們封裝好了。當(dāng)我們對模糊查詢非常熟悉了之后直接拿來時候即可。

概念說明

單字段模糊匹配:

說明:在一個字段中無論關(guān)鍵字出現(xiàn)在什么位置上,只要有關(guān)鍵詞即可。
場景:獲取手機(jī)號開頭為187的學(xué)生
應(yīng)用:SELECT*FROM table_name WHERE BINARY column_name LIKE'%keyword%';

多字段模糊匹配:

說明:在多個字段中無論關(guān)鍵字出現(xiàn)在什么位置上,只要每個字段有每個字段指定的關(guān)鍵詞即可。
場景:獲取手機(jī)號開頭為187并且姓氏為武的學(xué)生
應(yīng)用:SELECT*FROM table_name WHERE BINARY column1_name LIKE'%keyword1%'AND column2_name LIKE'%keyword2%';

??注:BINARY函數(shù)是開啟大小寫敏感的函數(shù),底層邏輯是通過Ascii碼的方式比較的。因為數(shù)據(jù)庫默認(rèn)是對大小寫不敏感的,也就是我們在查詢名稱為wzl數(shù)據(jù)的時候,也會把名稱為Wzl的數(shù)據(jù)也查詢出來。

實現(xiàn)過程

代碼實現(xiàn)

1.寫一個實體類去實現(xiàn)Specification接口,重寫toPredicate方法

import com.fasterxml.jackson.databind.annotation.JsonSerialize;
import com.tfjybj.dao.UserDao;
import com.tfjybj.utils.SnowflakeIdWorker;
import lombok.Data;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Example;
import org.springframework.data.jpa.domain.Specification;
import org.springframework.stereotype.Service;
import org.springframework.util.ObjectUtils;import javax.annotation.Resource;
import javax.persistence.*;
import javax.persistence.criteria.CriteriaBuilder;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Predicate;
import javax.persistence.criteria.Root;
import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;/*** @BelongsProject: incentive* @BelongsPackage: com.tfjybj.service* @Author: Wuzilong* @Description: 描述什么人干什么事兒* @CreateTime: 2023-08-28 14:48* @Version: 1.0*/
@Table
@Entity
@Service
@Data
public class User implements Specification<User> {@Id@JsonSerialize(using = com.fasterxml.jackson.databind.ser.std.ToStringSerializer.class)private Long id;private String account;private  String password;private String phone;private Date createTime;private Date updateTime;private Integer isDelete;@Resource@Transientprivate UserDao userDao;@Overridepublic Predicate toPredicate(Root<User> root, CriteriaQuery<?> criteriaQuery, CriteriaBuilder criteriaBuilder) {List<String> nonNullFields = new ArrayList<>();Field[] declaredFields = this.getClass().getDeclaredFields();for (Field field : declaredFields) {field.setAccessible(true);try {Object value = field.get(this);if (value != null) {nonNullFields.add(field.getName());}} catch (IllegalAccessException e) {e.printStackTrace();}}Predicate[] predicates = new Predicate[nonNullFields.size()+1];for (int i = 0; i < nonNullFields.size(); i++) {try {predicates[i] = criteriaBuilder.like(root.get(nonNullFields.get(i)), "%" + this.getClass().getDeclaredField(nonNullFields.get(i)).get(this) + "%");} catch (Exception e) {e.printStackTrace();}}// 添加額外的條件,排除isdelete=1的數(shù)據(jù)predicates[nonNullFields.size()] = criteriaBuilder.notEqual(root.get("isDelete"), 1);return criteriaBuilder.and(predicates);}
}

本文中實現(xiàn)的是and方式的模糊查詢,也可是使用or的方式進(jìn)行模糊查詢,也就是多個字段中都包含一個關(guān)鍵字。

2.定義一個接口去繼承JpaRepository接口,并指定返回的類型和參數(shù)類型

@Entity
import com.tfjybj.service.User;
import org.springframework.data.jpa.domain.Specification;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;import java.util.List;/*** @BelongsProject: incentive* @BelongsPackage: com.tfjybj.dao* @Author: Wuzilong* @Description: 描述什么人干什么事兒* @CreateTime: 2023-08-28 14:48* @Version: 1.0*/
@Repository
public interface UserDao extends JpaRepository<User, Long> {List<User> findAll(Specification<User> userInfo);
}

3.在業(yè)務(wù)類中調(diào)用聲明的接口

@Entitypublic List<User> selectToFuzzy(User userInfo){List<User> userInfoList = userDao.findAll(userInfo);return userInfoList;}

4.在Controller中直接調(diào)用業(yè)務(wù)類中的方法即可

    @RequestMapping(value="selectToFuzzy",method= RequestMethod.POST)//模糊查詢用戶的信息public List<User> selectToFuzzy(@RequestBody User userInfo){List<User> users = user.selectToFuzzy(userInfo);return users;}

執(zhí)行結(jié)果

在這里插入圖片描述

在這里插入圖片描述

??可以看到我們的入?yún)⒍际菍?yīng)字段值的一部分內(nèi)容,phone字段傳入的是187它會把phone字段中包含187的所有數(shù)據(jù)都返回回來。同樣兩個字段一起模糊查詢也是一樣。

其他方式

1.使用JPQL進(jìn)行模糊查詢:

使用LIKE關(guān)鍵字結(jié)合通配符(%)進(jìn)行模糊匹配。
例如:SELECT e FROM Employee e WHERE e.name LIKE '%John%'

2.使用Spring Data JPA的Query By Example進(jìn)行模糊查詢:

創(chuàng)建一個實體對象作為查詢條件,設(shè)置需要模糊匹配的屬性值。
例如:ExampleMatcher matcher = ExampleMatcher.matching().withMatcher("name", match -> match.contains()); Example<Employee> example = Example.of(employee, matcher);

3.使用Spring Data JPA的@Query注解進(jìn)行模糊查詢:

在Repository接口中使用@Query注解定義自定義的查詢方法。
在查詢方法中使用%通配符進(jìn)行模糊匹配。
例如:@Query("SELECT e FROM Employee e WHERE e.name LIKE %?1%") List<Employee> findByName(String name);

總結(jié)提升

??根據(jù)自己的業(yè)務(wù)需求去選擇使用哪一種模糊查詢的方式。底層原理都是一樣的。JPA封裝了一些公共的內(nèi)容,我們開發(fā)的過程中使用起來就比較容易和簡單。但是我們在使用的過程中也要明白底層是如何實現(xiàn),不能只停留在會使用的階段中。知其然也要知其所以然。


🎯 此文章對你有用的話記得留言+點(diǎn)贊+收藏哦🎯
http://www.risenshineclean.com/news/27883.html

相關(guān)文章:

  • 古典asp網(wǎng)站源碼百度客服中心人工在線電話
  • 石家莊做外貿(mào)網(wǎng)站seo搜索引擎優(yōu)化關(guān)鍵詞
  • seo全套視頻教程信息流優(yōu)化
  • 電商購物網(wǎng)站建設(shè)杭州網(wǎng)站優(yōu)化流程
  • 網(wǎng)站設(shè)計如何做策劃黃頁推廣平臺有哪些
  • 豐臺網(wǎng)站建設(shè)推廣seo優(yōu)化關(guān)鍵詞的方法
  • 剛做的網(wǎng)站怎么在百度搜到西安霸屏推廣
  • 怎樣開發(fā)游戲app軟件優(yōu)化推廣網(wǎng)站怎么做最好
  • 如何建英文網(wǎng)站全網(wǎng)營銷式網(wǎng)站
  • 電子商務(wù)網(wǎng)站建設(shè)商城網(wǎng)站百度網(wǎng)站推廣一年多少錢
  • 中企動力做的網(wǎng)站被鏡像怎么能在百度上做推廣
  • 招聘網(wǎng)站的SEO怎么做大數(shù)據(jù)營銷經(jīng)典案例
  • 網(wǎng)站備案需要花錢嗎東莞網(wǎng)絡(luò)推廣平臺
  • 網(wǎng)站開發(fā)的就業(yè)寧波網(wǎng)絡(luò)推廣軟件
  • 云南做網(wǎng)站多少錢市場調(diào)研方案怎么寫
  • 營銷技巧第三季在線觀看鄭州厲害的seo優(yōu)化顧問
  • 寫網(wǎng)站編程需要什么百度快照替代
  • 會計可以做網(wǎng)站么真實的網(wǎng)站制作
  • 新鄉(xiāng)網(wǎng)站推廣公司微信運(yùn)營
  • 中國建設(shè)銀行行網(wǎng)站谷歌優(yōu)化的最佳方案
  • 做漁具最大的外貿(mào)網(wǎng)站營銷方案案例范文
  • 做教育網(wǎng)站多少錢淘寶推廣引流方法有哪些
  • 網(wǎng)站開發(fā)技術(shù)教程百度搜索指數(shù)是怎么計算的
  • 企業(yè)網(wǎng)站制作機(jī)構(gòu)排名怎樣進(jìn)行關(guān)鍵詞推廣
  • 微信公眾平臺客服谷歌seo培訓(xùn)
  • 做商城網(wǎng)站需要什么資質(zhì)海南網(wǎng)站制作
  • 做網(wǎng)站和做推廣有什么區(qū)別站內(nèi)推廣
  • 新鄉(xiāng)網(wǎng)站建設(shè)哪家好seo包年服務(wù)
  • 網(wǎng)站備案要求北京seo薪資
  • 西安是哪個省屬于哪個省專業(yè)網(wǎng)站推廣優(yōu)化