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.mzph.cn/diannao/36448.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java基于ssm+jsp 弹幕视频网站

1前台首页功能模块 弹幕视频网站&#xff0c;在弹幕视频网站可以查看首页、视频信息、商品信息、论坛信息、我的、跳转到后台、购物车、客服等内容&#xff0c;如图1所示。 图1前台首页界面图 登录&#xff0c;通过登录填写账号、密码等信息进行登录操作&#xff0c;如图2所示…

显卡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类五、集合…

恭喜朱雀桥的越南薇妮她牌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; 哈夫曼树 哈夫曼树&#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[面试题]消息队列[面试题]…

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…

配置 Cmder 到鼠标右键

win Q 快捷键搜索 cmd&#xff0c;以管理员身份运行 在命令行输入 cmder.exe /REGISTER ALL

OpenCloudOS开源的操作系统

OpenCloudOS 是一款开源的操作系统&#xff0c;致力于提供高性能、稳定和安全的操作系统环境&#xff0c;以满足现代计算和应用程序的需求。它结合了现代操作系统设计的最新技术和实践&#xff0c;为开发者和企业提供了一个强大的平台。本文将详细介绍 OpenCloudOS 的背景、特性…

品牌进行3D数字化转型,有哪些优势?

各行业都在经历着从增量市场向存量市场的转变&#xff0c;同时用户的消费观念也日趋成熟&#xff0c;更加注重产品的体验和服务质量。 无论是线上购物平台还是线下实体门店&#xff0c;提供个性化和增强体验感的产品与服务已成为未来发展的核心驱动力&#xff0c;品牌转型也迫…

SyncFolders文件备份—办公人员必备

SyncFolders支持在两个或多个文件夹之间同步文件&#xff0c;用户可以将重要文件同步到多个位置&#xff0c;如备份硬盘、网络共享文件夹或云存储等。通过设定同步规则&#xff0c;可以自动备份和同步更新&#xff0c;减少手动操作的繁琐&#xff0c;确保文件的安全和可访问性。…

uniapp横屏移动端卡片缩进轮播图

uniapp横屏移动端卡片缩进轮播图 效果&#xff1a; 代码&#xff1a; <!-- 简单封装轮播图组件:swiperCard --> <template><swiper class"swiper" circular :indicator-dots"true" :autoplay"true" :interval"10000&quo…

软件必须要进行跨浏览器测试吗?包括哪些内容和注意事项?

随着互联网的普及和发展&#xff0c;用户对软件的要求越来越高。无论是在台式机、笔记本还是移动设备上&#xff0c;用户都希望能够以最好的体验来使用软件。然而&#xff0c;不同的浏览器在解析网页的方式、支持的技术标准等方面存在差异&#xff0c;这就导致了同一个网页在不…

fpga bitstream userid

fpga version register # xdc 文件 set_property BITSTREAM.CONFIG.USERID "0xDEADC0DE" [current_design] set_property BITSTREAM.CONFIG.USR_ACCESS 0x66669999 [current_design]ug908 在bit下载之后的property可以看到 &#xff0c;GUI里面Tools → Edit Devic…