003 SpringBoot操作ElasticSearch7.x

文章目錄

    • 5.SpringBoot集成ElasticSearch7.x
      • 1.添加依賴
      • 2.yml配置
      • 3.創建文檔對象
      • 4.繼承ElasticsearchRepository
      • 5.注入ElasticsearchRestTemplate
    • 6.SpringBoot操作ElasticSearch
      • 1.ElasticsearchRestTemplate索引操作
      • 2.ElasticsearchRepository文檔操作
      • 3.ElasticsearchRestTemplate文檔操作
      • 4.ElasticsearchRestTemplate數據檢索
    • 完整測試代碼

5.SpringBoot集成ElasticSearch7.x

1.添加依賴

本文使用springboot版本為2.7

    <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-elasticsearch</artifactId></dependency>

spring官網es對應版本關系 https://docs.spring.io/spring-data/elasticsearch/reference/elasticsearch/versions.html

2.yml配置

spring:data:elasticsearch:repositories:enabled: true  #打開elasticsearch倉庫,默認trueelasticsearch:#username:#password:#path-prefix:uris: http://127.0.0.1:9200connection-timeout: 60000   #連接elasticsearch超時時間socket-timeout: 30000

3.創建文檔對象

/*** @author moshangshang* createIndex默認為true自動創建索引*/
@Data
@AllArgsConstructor
@Document(indexName ="books",createIndex = true)
public class Books implements Serializable {@Idprivate Integer id;//指定字段類型和分詞器@Field(type = FieldType.Text, analyzer = "ik_max_word")private String name;@Field(type = FieldType.Text, analyzer = "ik_max_word")private String describe;}
public enum FieldType {Text,Integer,Long,Date,Float,Double,Boolean,Object,Auto,Nested,Ip,Attachment,Keyword
}
@GeoPointField  //地理位置類型字段
private GeoPoint location;
@Field(index = false) //不進行索引

4.繼承ElasticsearchRepository

/*** @author moshangshang*/
public interface BookMapper extends ElasticsearchRepository<Books,String> {
}

自定義接口查詢方法

 List<Book> findByNameAndPrice(String name, Integer price);

等同于

{"query": {"bool" : {"must" : [{ "query_string" : { "query" : "?", "fields" : [ "name" ] } },{ "query_string" : { "query" : "?", "fields" : [ "price" ] } }]}}
}

詳細接口方法命名見官方文檔:

https://docs.spring.io/spring-data/elasticsearch/reference/elasticsearch/repositories/elasticsearch-repository-queries.html

5.注入ElasticsearchRestTemplate

   @Autowiredprivate ElasticsearchRestTemplate elasticsearchRestTemplate;

建議通過elasticsearchRestTemplate進行es操作,ElasticsearchRepository也可直接操作,但多數方法已過時,不建議用

6.SpringBoot操作ElasticSearch

1.ElasticsearchRestTemplate索引操作

   /*** 操作文檔索引* 如果文檔的createIndex設置為true自動創建,則可以直接創建映射會自動創建索引* 如果為false,直接創建映射會返回Document的json,但索引并未創建*/@GetMapping("/create/index")public Document createIndex(){// 獲取操作的索引文檔對象IndexOperations indexOperations = elasticsearchRestTemplate.indexOps(Books.class);//判斷索引是否存在log.info("exists:{}",indexOperations.exists());//刪除索引文檔log.info("delete:{}",indexOperations.delete());//創建索引,如果存在則會拋異常log.info("create:{}",indexOperations.create());//創建映射,返回Documentlog.info("createMapping:{}",indexOperations.createMapping());indexOperations.delete();//創建索引同時創建映射,如果存在索引則會拋異常log.info("createWithMapping{}",indexOperations.createWithMapping());//更新映射mappinglog.info("putMapping:{}",indexOperations.putMapping());// 配置映射return indexOperations.createMapping();}

2.ElasticsearchRepository文檔操作

 /*** 發送保存數據,會自動創建索引文檔并保存數據* 如果文檔的createIndex設置為false,該方法會創建索引*/@GetMapping("/data/{id}")public String data(@PathVariable Integer id){//新增數據,等同于PUT/POST方式發送數據bookMapper.save(new Books(id,"四大名著西游記111","著名的神話小說"));//查所有數據bookMapper.findAll().forEach(System.out::println);bookMapper.findAllById(Arrays.asList("1", "10")).forEach(System.out::println);bookMapper.findById(id.toString()).ifPresent(System.out::println);//查所有數據按id排序bookMapper.findAll(Sort.by("id")).forEach(System.out::println);//刪除指定id數據bookMapper.deleteById(String.valueOf(id));//分頁查詢Page<Books> booksPage = bookMapper.findAll(Pageable.ofSize(2));//效果等同于booksPage2.getContent().forEach()log.info("總頁數:{}",booksPage.getTotalPages());System.out.println("第1頁");booksPage.forEach(System.out::println);int i = 1;//判斷是否有下一頁,hasPrevious方法判斷是否有前一頁while (booksPage.hasNext()){i++;booksPage = bookMapper.findAll(booksPage.nextPageable());log.info("第{}頁",i);booksPage.forEach(System.out::println);}return "success";}

3.ElasticsearchRestTemplate文檔操作

注意:直接執行可能會刪除時更新操作還未執行完,全部刪除時會導致更新的數據還在

    @GetMapping("/data1/{id}")public UpdateResponse data1(@PathVariable Integer id){//添加 elasticsearchRestTemplate.save(new Books(id,"四大名著西游記111","著名的神話小說"));elasticsearchRestTemplate.save(new Books(1,"四大名著西游記111","著名的神話小說"),new Books(2,"四大名著西游記111","著名的神話小說"),new Books(3,"四大名著西游記111","著名的神話小說"));/*** 修改 跟新增是相同。若id已存在,覆蓋其他所有字段,* 若某個字段沒有值,則為null。無法修改單個字段*/elasticsearchRestTemplate.save(new Books(3,"四大名著西游記222",null));//修改部分字段Document document = Document.create();document.put("name", "三國演義");document.put("describe", "著名的小說");//需要修改的id和參數UpdateQuery updateQuery = UpdateQuery.builder(String.valueOf(id)).withDocument(document).build();UpdateResponse response = elasticsearchRestTemplate.update(updateQuery, IndexCoordinates.of("books"));//批量修改部分字段List<UpdateQuery> updateQueryList = new ArrayList<>();for (int i = 1; i <= 3; i++) {Document bulkDocument = Document.create();bulkDocument.put("name", "三國演義"+i);bulkDocument.put("describe", "著名的小說"+i);//索引i數據不存在會報錯UpdateQuery updateQueryBulk = UpdateQuery.builder(Long.toString(i)).withDocument(bulkDocument).build();updateQueryList.add(updateQueryBulk);}elasticsearchRestTemplate.bulkUpdate(updateQueryList, IndexCoordinates.of("books"));//查詢Books books = elasticsearchRestTemplate.get(id.toString(), Books.class, IndexCoordinates.of("books"));log.info("查詢數據:{}",books);//刪除String delete = elasticsearchRestTemplate.delete(id.toString(), Books.class);log.info("刪除數據id:{}",delete);//條件刪除NativeSearchQuery nativeSearchQuery = new NativeSearchQueryBuilder().withQuery(QueryBuilders.matchQuery("name", "三國")).build();ByQueryResponse queryResponse = elasticsearchRestTemplate.delete(nativeSearchQuery, Books.class, IndexCoordinates.of("books"));log.info("刪除queryResponse數據數量:{}",queryResponse.getDeleted());//全部刪除//直接執行可能會刪除時更新操作還未執行完,全部刪除時會導致更新的數據還在ByQueryResponse queryResponse1 = elasticsearchRestTemplate.delete(new NativeSearchQueryBuilder().withQuery(QueryBuilders.matchAllQuery()).build(),Books.class, IndexCoordinates.of("books"));log.info("刪除queryResponse1數據數量:{}",queryResponse1.getDeleted());return response;}

4.ElasticsearchRestTemplate數據檢索

基礎高亮查詢

   @GetMapping("/query")public void query() {// 構建查詢條件(NativeSearchQueryBuilder更接近原生查詢)NativeSearchQueryBuilder queryBuilder = new NativeSearchQueryBuilder();//查詢queryBuilder.withQuery(QueryBuilders.matchQuery("username","lisi")).withSort(Sort.by("age").ascending());//高亮查詢HighlightBuilder highlightBuilder = new HighlightBuilder();highlightBuilder.field("username");//多個匹配項高亮關閉highlightBuilder.requireFieldMatch(false);highlightBuilder.preTags("<span style='color:red'>");highlightBuilder.postTags("</span>");//設置高亮queryBuilder.withHighlightBuilder(highlightBuilder);SearchHits<News> searchHits = elasticsearchRestTemplate.search(queryBuilder.build(), News.class);searchHits.forEach(e -> {log.info("全文檢索{}", e.getContent());Map<String, List<String>> highlightFields = e.getHighlightFields();List<String> list = highlightFields.get("username");if (list != null) {list.forEach(ex -> log.info("高亮{}", ex));}});}

NativeSearchQueryBuilder條件構建

 // 構建查詢條件(NativeSearchQueryBuilder更接近原生查詢)NativeSearchQueryBuilder queryBuilder = new NativeSearchQueryBuilder();  //查詢全部 match_allqueryBuilder.withQuery(QueryBuilders.matchAllQuery());  //查詢全部 過濾時間范圍queryBuilder.withQuery(QueryBuilders.matchAllQuery()).withFilter(QueryBuilders.rangeQuery("time").timeZone("+08:00").format("yyyy-MM-dd HH:mm:ss").gt("2024-06-27 14:22:22").lt("2024-06-27 14:22:28"));//查詢全部 match_all 并按age升序queryBuilder.withQuery(QueryBuilders.matchAllQuery()).withSort(Sort.by("age").ascending());//查詢全部 match_all 并按age升序 并分頁queryBuilder.withQuery(QueryBuilders.matchAllQuery()).withSort(Sort.by("age").ascending()).withPageable(PageRequest.of(2, 10));//term精確查詢,整體匹配// 查詢內容只是為數字時 推薦使用term 進行檢索,但是當使用term中進行文本內容的全量檢索時term不會檢索任何內容queryBuilder.withQuery(QueryBuilders.termQuery("age", "2"));//多匹配值查詢queryBuilder.withQuery(QueryBuilders.termsQuery("age", "2", "3"));//全文檢索 match_queryqueryBuilder.withQuery(QueryBuilders.matchQuery("address", "Beijing"));//or 只要有一個詞存在則就符合條件,and表示每個詞都需存在queryBuilder.withQuery(QueryBuilders.matchQuery("address", "Beijing shanghai").operator((Operator.OR)));//短語匹配 match_phrasequeryBuilder.withQuery(QueryBuilders.matchPhraseQuery("address", "Beijing aaa"));//短語匹配 match_phrase_prefix 它允許文本中最后一項使用前綴匹配queryBuilder.withQuery(QueryBuilders.matchPhrasePrefixQuery("address", "Beijing a"));//多字段匹配 multi_matchqueryBuilder.withQuery(QueryBuilders.multiMatchQuery("Beijing aaa", "address", "username"));queryBuilder.withQuery(QueryBuilders.multiMatchQuery("Beijing aaa", "address", "username")//提升該字段查詢匹配權重.field("address", 10));//match_bool_prefix 允許文本中最后一項使用前綴匹配 其它都是term query。queryBuilder.withQuery(QueryBuilders.matchBoolPrefixQuery("address", "b"));//id查詢queryBuilder.withQuery(QueryBuilders.idsQuery().addIds("1", "2"));//區間查詢queryBuilder.withQuery(QueryBuilders.rangeQuery("age").gte(2).lte(3));//bool復合查詢//must必須  mustNot必須不//should 條件可以滿足也可以不滿足,在查詢中如果有滿足should的條件就會增加相關性得分QueryBuilders.boolQuery().must(QueryBuilders.matchQuery("address", "Beijing")).must(QueryBuilders.matchQuery("username", "lisi")).mustNot(QueryBuilders.matchQuery("age", "1")).should(QueryBuilders.matchQuery("age", "2"))//minimumShouldMatch 最小匹配度,必須 匹配的should子句的數量或百分比。.minimumShouldMatch("50%");//filter結果過濾QueryBuilders.boolQuery().filter(QueryBuilders.rangeQuery("age").gte(1).lte(2));//與上面結果相等QueryBuilders.boolQuery().must(QueryBuilders.rangeQuery("age").gte(1).lte(2));

完整測試代碼

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.7.0</version></parent><groupId>com.example</groupId><artifactId>test</artifactId><version>0.0.1-SNAPSHOT</version><name>test</name><properties><java.version>8</java.version></properties><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-elasticsearch</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-devtools</artifactId><scope>runtime</scope><optional>true</optional></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><optional>true</optional></dependency></dependencies><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId><configuration><excludes><exclude><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId></exclude></excludes></configuration></plugin></plugins></build></project>
/*** @author moshangshang*/
@Data
@AllArgsConstructor
@Document(indexName ="news")
public class News implements Serializable {@Idprivate Integer id;@Field(type = FieldType.Text, analyzer = "ik_max_word")private String address;@Field(type = FieldType.Text, analyzer = "ik_max_word")private String username;@Field(type = FieldType.Long)private Integer age;
}

/*** @author moshangshang*/
@Data
@AllArgsConstructor
@Document(indexName ="books")
public class Books implements Serializable {@Idprivate Integer id;@Field(type = FieldType.Text, analyzer = "ik_max_word")private String name;@Field(type = FieldType.Text, analyzer = "ik_max_word")private String describe;}

/*** @author moshangshang*/
public interface BookMapper extends ElasticsearchRepository<Books,String> {
}
/*** @author moshangshang*/
@Slf4j
@RestController
@RequestMapping("/es")
public class BookController {@Autowiredprivate BookMapper bookMapper;@Autowiredprivate ElasticsearchRestTemplate elasticsearchRestTemplate;/*** 操作文檔索引* 如果文檔的createIndex設置為true自動創建,則可以直接創建映射會自動創建索引* 如果為false,直接創建映射會返回Document的json,但索引并未創建*/@GetMapping("/create/index")public Document createIndex() {// 獲取操作的索引文檔對象IndexOperations indexOperations = elasticsearchRestTemplate.indexOps(Books.class);//判斷索引是否存在log.info("exists:{}", indexOperations.exists());//刪除索引文檔log.info("delete:{}", indexOperations.delete());//創建索引,如果存在則會拋異常log.info("create:{}", indexOperations.create());//創建映射,返回Documentlog.info("createMapping:{}", indexOperations.createMapping());indexOperations.delete();//創建索引同時創建映射,如果存在索引則會拋異常log.info("createWithMapping{}", indexOperations.createWithMapping());//更新映射mappinglog.info("putMapping:{}", indexOperations.putMapping());// 配置映射return indexOperations.createMapping();}/*** 發送保存數據,會自動創建索引文檔并保存數據* 如果文檔的createIndex設置為false,該方法會創建索引*/@GetMapping("/data/{id}")public String data(@PathVariable Integer id) {//新增數據bookMapper.save(new Books(id, "四大名著西游記111", "著名的神話小說"));//查所有數據bookMapper.findAll().forEach(System.out::println);bookMapper.findAllById(Arrays.asList("1", "10")).forEach(System.out::println);bookMapper.findById(id.toString()).ifPresent(System.out::println);//查所有數據按id排序bookMapper.findAll(Sort.by("id")).forEach(System.out::println);//刪除指定id數據//bookMapper.deleteById(String.valueOf(id));//刪除匹配的數據bookMapper.delete(new Books(null, "四大名著西游記111", "著名的神話小說"));//刪除所有數據//bookMapper.deleteAll();//分頁查詢Page<Books> booksPage = bookMapper.findAll(Pageable.ofSize(2));//效果等同于booksPage2.getContent().forEach()log.info("總頁數:{}", booksPage.getTotalPages());System.out.println("第1頁");booksPage.forEach(System.out::println);int i = 1;//判斷是否有下一頁,hasPrevious方法判斷是否有前一頁while (booksPage.hasNext()) {i++;booksPage = bookMapper.findAll(booksPage.nextPageable());log.info("第{}頁", i);booksPage.forEach(System.out::println);}return "success";}@GetMapping("/data1/{id}")public UpdateResponse data1(@PathVariable Integer id) {//添加elasticsearchRestTemplate.save(new Books(id, "四大名著西游記111", "著名的神話小說"));elasticsearchRestTemplate.save(new Books(1, "四大名著西游記111", "著名的神話小說"),new Books(2, "四大名著西游記111", "著名的神話小說"),new Books(3, "四大名著西游記111", "著名的神話小說"));/*** 修改 跟新增是相同。若id已存在,覆蓋其他所有字段,* 若某個字段沒有值,則為null。無法修改單個字段*/elasticsearchRestTemplate.save(new Books(3, "四大名著西游記222", null));//修改部分字段Document document = Document.create();document.put("name", "三國演義");document.put("describe", "著名的小說");//需要修改的id和參數UpdateQuery updateQuery = UpdateQuery.builder(String.valueOf(id)).withDocument(document).build();UpdateResponse response = elasticsearchRestTemplate.update(updateQuery, IndexCoordinates.of("books"));//批量修改部分字段List<UpdateQuery> updateQueryList = new ArrayList<>();for (int i = 1; i <= 3; i++) {Document bulkDocument = Document.create();bulkDocument.put("name", "三國演義" + i);bulkDocument.put("describe", "著名的小說" + i);//索引i數據不存在會報錯UpdateQuery updateQueryBulk = UpdateQuery.builder(Long.toString(i)).withDocument(bulkDocument).build();updateQueryList.add(updateQueryBulk);}elasticsearchRestTemplate.bulkUpdate(updateQueryList, IndexCoordinates.of("books"));//查詢Books books = elasticsearchRestTemplate.get(id.toString(), Books.class, IndexCoordinates.of("books"));log.info("查詢數據:{}", books);//刪除String delete = elasticsearchRestTemplate.delete(id.toString(), Books.class);log.info("刪除數據id:{}", delete);//條件刪除NativeSearchQuery nativeSearchQuery = new NativeSearchQueryBuilder().withQuery(QueryBuilders.matchQuery("name", "三國")).build();ByQueryResponse queryResponse = elasticsearchRestTemplate.delete(nativeSearchQuery, Books.class, IndexCoordinates.of("books"));log.info("刪除queryResponse數據數量:{}", queryResponse.getDeleted());//全部刪除//直接執行可能會刪除時更新操作還未執行完,全部刪除時會導致更新的數據還在ByQueryResponse queryResponse1 = elasticsearchRestTemplate.delete(new NativeSearchQueryBuilder().withQuery(QueryBuilders.matchAllQuery()).build(),Books.class, IndexCoordinates.of("books"));log.info("刪除queryResponse1數據數量:{}", queryResponse1.getDeleted());return response;}@GetMapping("/query")public void query() {// 構建查詢條件(NativeSearchQueryBuilder更接近原生查詢)NativeSearchQueryBuilder queryBuilder = new NativeSearchQueryBuilder();//查詢全部 match_allqueryBuilder.withQuery(QueryBuilders.matchAllQuery());//查詢全部 過濾時間范圍queryBuilder.withQuery(QueryBuilders.matchAllQuery()).withFilter(QueryBuilders.rangeQuery("time").timeZone("+08:00").format("yyyy-MM-dd HH:mm:ss").gt("2024-06-27 14:22:22").lt("2024-06-27 14:22:28"));//查詢全部 match_all 并按age升序queryBuilder.withQuery(QueryBuilders.matchAllQuery()).withSort(Sort.by("age").ascending());//查詢全部 match_all 并按age升序 并分頁queryBuilder.withQuery(QueryBuilders.matchAllQuery()).withSort(Sort.by("age").ascending()).withPageable(PageRequest.of(2, 10));//term精確查詢,整體匹配// 查詢內容只是為數字時 推薦使用term 進行檢索,但是當使用term中進行文本內容的全量檢索時term不會檢索任何內容queryBuilder.withQuery(QueryBuilders.termQuery("age", "2"));//多匹配值查詢queryBuilder.withQuery(QueryBuilders.termsQuery("age", "2", "3"));//全文檢索 match_queryqueryBuilder.withQuery(QueryBuilders.matchQuery("address", "Beijing"));//or 只要有一個詞存在則就符合條件,and表示每個詞都需存在queryBuilder.withQuery(QueryBuilders.matchQuery("address", "Beijing shanghai").operator((Operator.OR)));//短語匹配 match_phrasequeryBuilder.withQuery(QueryBuilders.matchPhraseQuery("address", "Beijing aaa"));//短語匹配 match_phrase_prefix 它允許文本中最后一項使用前綴匹配queryBuilder.withQuery(QueryBuilders.matchPhrasePrefixQuery("address", "Beijing a"));//多字段匹配 multi_matchqueryBuilder.withQuery(QueryBuilders.multiMatchQuery("Beijing aaa", "address", "username"));queryBuilder.withQuery(QueryBuilders.multiMatchQuery("Beijing aaa", "address", "username")//提升該字段查詢匹配權重.field("address", 10));//match_bool_prefix 允許文本中最后一項使用前綴匹配 其它都是term query。queryBuilder.withQuery(QueryBuilders.matchBoolPrefixQuery("address", "b"));//id查詢queryBuilder.withQuery(QueryBuilders.idsQuery().addIds("1", "2"));//區間查詢queryBuilder.withQuery(QueryBuilders.rangeQuery("age").gte(2).lte(3));//bool復合查詢//must必須  mustNot必須不//should 條件可以滿足也可以不滿足,在查詢中如果有滿足should的條件就會增加相關性得分QueryBuilders.boolQuery().must(QueryBuilders.matchQuery("address", "Beijing")).must(QueryBuilders.matchQuery("username", "lisi")).mustNot(QueryBuilders.matchQuery("age", "1")).should(QueryBuilders.matchQuery("age", "2"))//minimumShouldMatch 最小匹配度,必須 匹配的should子句的數量或百分比。.minimumShouldMatch("50%");//filter結果過濾QueryBuilders.boolQuery().filter(QueryBuilders.rangeQuery("age").gte(1).lte(2));//與上面結果相等QueryBuilders.boolQuery().must(QueryBuilders.rangeQuery("age").gte(1).lte(2));//查詢queryBuilder.withQuery(QueryBuilders.matchQuery("username","lisi")).withSort(Sort.by("age").ascending());//高亮查詢HighlightBuilder highlightBuilder = new HighlightBuilder();highlightBuilder.field("username");//多個匹配項高亮關閉highlightBuilder.requireFieldMatch(false);highlightBuilder.preTags("<span style='color:red'>");highlightBuilder.postTags("</span>");//設置高亮queryBuilder.withHighlightBuilder(highlightBuilder);SearchHits<News> searchHits = elasticsearchRestTemplate.search(queryBuilder.build(), News.class);searchHits.forEach(e -> {log.info("全文檢索{}", e.getContent());Map<String, List<String>> highlightFields = e.getHighlightFields();List<String> list = highlightFields.get("username");if (list != null) {list.forEach(ex -> log.info("高亮{}", ex));}});}}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/36448.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/36448.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/36448.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

git tag 打標簽指南

參考 Pro Git 打標簽 查看標簽 git tag git tag -l 創建標簽 git tag tag002 創建了名稱是 tag002 的標簽&#xff0c;打在最新提交的 commit 上。只是打在本地&#xff0c;沒有推送到遠程。 如果要給以前的 commitId 打標簽&#xff0c;就用 git tag tag001 159e40 給 159e4…

java基于ssm+jsp 彈幕視頻網站

1前臺首頁功能模塊 彈幕視頻網站&#xff0c;在彈幕視頻網站可以查看首頁、視頻信息、商品信息、論壇信息、我的、跳轉到后臺、購物車、客服等內容&#xff0c;如圖1所示。 圖1前臺首頁界面圖 登錄&#xff0c;通過登錄填寫賬號、密碼等信息進行登錄操作&#xff0c;如圖2所示…

GPT-5即將登場:期待AI新時代的技術突破與人機高效協作

隨著科技的飛速發展&#xff0c;我們即將迎來一個人工智能領域的重要里程碑——GPT-5的發布。這一技術革新無疑是一個激動人心的時刻&#xff0c;它預示著AI技術將邁向一個全新的高度。GPT-5作為人工智能領域的一大突破&#xff0c;有望為我們帶來前所未有的應用場景與深遠影響…

顯卡GTX與RTX有什么區別?哪一個更適合玩游戲?

游戲發燒友們可能對游戲顯卡并不陌生&#xff0c;它直接關系到游戲畫面的流暢度、細膩程度和真實感。在眾多顯卡品牌中&#xff0c;英偉達的GTX和RTX系列顯卡因其出色的性能而備受關注。 一、GTX與RTX的區別 架構差異 GTX系列顯卡采用的是Pascal架構&#xff0c;這是英偉達在…

探索MySQL核心技術:理解索引和主鍵的關系

在數據密集型應用中&#xff0c;數據庫的性能往往是決定一個應用成敗的重要因素之一。其中&#xff0c;MySQL作為一種開源關系型數據庫管理系統&#xff0c;以其卓越的性能和豐富的功能被廣泛應用。而在MySQL數據庫優化的眾多技巧中&#xff0c;索引和主鍵扮演著極其重要的角色…

安霸CVFlow推理開發筆記

一、安霸環境搭建&#xff1a; 1.遠程172.20.62.13 2. 打開Virtualbox&#xff0c;所在目錄&#xff1a;E:\Program Files\Oracle\VirtualBox 3. 配置好ubuntu18.04環境&#xff0c;Ubuntu密碼&#xff1a;amba 4. 安裝toolchain&#xff0c;解壓Ambarella_Toolchain_CNNGe…

鴻蒙開發HarmonyOS NEXT (二) 熟悉ArkUI

一、構造函數 構造一個商品類Item&#xff0c;然后利用foreach函數循環渲染 class Item {name: stringimage: ResourceStrprice: numberdiscount: numberconstructor(name: string, image: ResourceStr, price: number, discount: number 0) {this.name name;this.image ima…

JAVA進階學習09

文章目錄 一、雙列集合Map1.1 雙列集合介紹1.2 雙列集合Map常見API1.3 Map集合遍歷方式1.3.1 通過集合的全部鍵來遍歷集合1.3.2 Map集合遍歷方式21.3.3 Map集合遍歷方式3 二、Map集合的實現類2.1 HashMap類2.2 LinkedHashMap2.3 TreeMap 三、可變參數四、Collections類五、集合…

Vue 2.0 與 3.0區別

Vue.js是一種流行的前端JavaScript框架&#xff0c;用于構建用戶界面和單頁面應用程序。隨著時間的推移&#xff0c;Vue.js已經從Vue2發展到了Vue3&#xff0c;這兩個版本在**生命周期、模板組件以及性能**等方面有顯著差異。具體分析如下&#xff1a; 1. **生命周期** - **Vue…

恭喜朱雀橋的越南薇妮她牌NFC山竹汁飲料,成為霸王茶姬奶茶主材

朱雀橋NFC山竹汁飲料&#xff1a;榮登霸王茶姬奶茶主材&#xff0c;非遺傳承的天然之選 近日&#xff0c;據小編了解到&#xff1a;霸王茶姬欣喜地宣布&#xff0c;成功與朱雀橋達成合作越南薇妮她VINUT牌NFC山竹汁飲料。這款商超產品憑借其卓越的品質與獨特的口感&#xff0c…

PostgreSQL安裝教程及文件介紹

Ubuntu 安裝和配置 PostgreSQL 以 Ubuntu Server 20.04&#xff0c;PostgreSQL 12 版本為例。 1. 安裝 使用如下命令&#xff0c;安裝指定版本的 PostgreSQL sudo apt install postgresql-12在 Ubuntu 20.04 中安裝 PostgreSQL 登錄您的 Ubuntu 系統并使用以下 apt 命令更新…

Java web應用性能分析之【prometheus監控指標體系】

Java web應用性能分析之【系統監控工具prometheus】_javaweb服務器性能監控工具-CSDN博客 Java web應用性能分析之【prometheusGrafana監控springboot服務和服務器監控】_grafana 導入 prometheus-CSDN博客 因為篇幅原因&#xff0c;前面沒有詳細說明Prometheus的監控指標&…

將手機上的已安裝應用拷貝出到電腦中

方法一&#xff1a;通過應用管理器 下載并安裝應用管理器&#xff1a;可以使用應用管理器如“ES文件瀏覽器”或“APK Extractor”。 提取APK文件&#xff1a; 打開應用管理器。 找到已安裝的應用程序列表。 選擇你想要提取的應用程序&#xff0c;然后選擇“提取”或“備份”選…

數據結構 —— 哈夫曼樹

數據結構 —— 哈夫曼樹 哈夫曼樹定義構造算法特性應用 哈夫曼編碼核心概念工作原理特點 我們今天來看哈夫曼樹&#xff1a; 哈夫曼樹 哈夫曼樹&#xff08;Huffman Tree&#xff09;&#xff0c;是一種特殊的二叉樹&#xff0c;由D.A. Huffman在1952年提出&#xff0c;主要用…

[面試題]計算機網絡

[面試題]Java【基礎】[面試題]Java【虛擬機】[面試題]Java【并發】[面試題]Java【集合】[面試題]MySQL[面試題]Maven[面試題]Spring Boot[面試題]Spring Cloud[面試題]Spring MVC[面試題]Spring[面試題]MyBatis[面試題]Nginx[面試題]緩存[面試題]Redis[面試題]消息隊列[面試題]…

ES報錯:解決too_many_clauses: maxClauseCount is set to 1024 報錯問題

解決too_many_clauses: maxClauseCount is set to 1024 報錯問題 問題場景報錯信息問題分析解決1. 優化查詢2. 增加maxClauseCount3. 改用其他查詢類型修改后的查詢示例 問題場景 查詢語句&#xff1a;查詢clcNo分類號包含分類O的所有文檔 {"match_phrase_prefix":…

社會與網絡的討論#1

“拒絕心靈雞湯” 都說人人平等&#xff0c;那請問一個有錢人看到一個掃大街的&#xff0c;能有幾個保證不產生厭惡感的&#xff1f; 你能確保&#xff0c;你的工資會比有關系的人的工資高嗎&#xff1f; 你進入公司&#xff0c;有有關系的人進入的方便嗎&#xff1f; 在學…

特產零售元宇宙:探索虛擬世界的商業機遇

在數字化時代&#xff0c;元宇宙作為一個全新的虛擬世界&#xff0c;正在逐漸改變我們的生活方式和商業模式。隨著技術的不斷發展&#xff0c;特產零售業也開始嘗試進入這個充滿無限可能的新領域。本文將探討特產零售元宇宙的概念、優勢以及面臨的挑戰&#xff0c;并分析其未來…

WAIC2024 | 華院計算邀您共赴2024年世界人工智能大會,見證未來科技革新

在智能時代的浪潮洶涌澎湃之際&#xff0c;算法已成為推動社會進步的核心力量。作為中國認知智能技術的領軍企業&#xff0c;華院計算在人工智能的廣闊天地中&#xff0c;不斷探索、創新&#xff0c;致力于將算法的潛力發揮到極致。在過去的時日里&#xff0c;華院計算不斷探索…

Java - Execl自定義導入、導出

1.需求&#xff1a;問卷星答 下圖框出區域&#xff0c;為用戶自定義字段問題及答案 2.采用技術EasyExcel 模板所在位置如下 /*** 導出模板** param response*/ Override public void exportTemplate(HttpServletResponse response) throws IOException {ClassPathResource c…