热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

关于java:solr多字段分组统计数据并结合springboot通过ftl模板导出EXCEL

一、我的项目构造二、pom.xml在pom.xml文件中增加springboot、solr、freemarker相干的依赖包{代码}三、制作.ftl模板1、创立excel模板,并填充一些假数据,不便后续定位2、另存为xml格局3、批改后缀为ftl4、解决ftl文件记得将ss:ExpandedRowCount"5"删掉,因为前面循环遍历的时候必定会超过行数为5的限度,删除就示意不

一、我的项目构造

二、pom.xml
在pom.xml文件中增加springboot、solr、freemarker相干的依赖包

  
      
          org.springframework.boot
          spring-boot-starter-freemarker
      
      
          cn.hutool
          hutool-all
          5.2.0
      
      
      
          org.springframework.boot
          spring-boot-starter-web
      
      
      
      
          org.apache.solr
          solr-solrj
      
      
          org.springframework.boot
          spring-boot-starter-data-solr
      
      
          org.projectlombok
          lombok
          1.16.14
          provided
      
  

三、制作.ftl模板
1、创立excel模板,并填充一些假数据,不便后续定位

2、另存为xml格局

3、批改后缀为ftl

4、解决ftl文件

记得将ss:ExpandedRowCount=”5″删掉,因为前面循环遍历的时候必定会超过行数为5的限度,删除就示意不限度表格的行数

将stat.ftl放入resources/templates

四、在springboot上应用solr进行多字段分组统计数据

这里须要留神因为查看HttpSolrClient源码发现DEFAULT_PATH默认是”/select”,并且没找到能够批改path的中央,所以如果solr服务有自定义/select的状况下,就能够拷贝源码,而后在本地新建一个同名的HttpSolrClient,能够参考我的我的项目构造

拓展常识:solr中q与fq参数的区别?

如果用q=content:”中国”,就会查找所有content中蕴含”中国”的,而后order by score,这时就会按content的类似度来排序。

而如果用fq,q设置为:。那么solr会先order by score,而因为条件是:,所以所有文档的相关性都是一样的,所以即应用fq过滤了,返回排在最后面的却不是相关性最高的。

综上所述,以相关性(score)为优先排序条件的,那么条件肯定放在q参数中,而fq仅仅只是条件的过滤而没有权重相关性为优先排序。

五、封装完数据并渲染到ftl模板,导出EXCEL


大家可能会遇到模板导出的时候报错,提醒template not found(模板未找到),这时候须要到application.yml配置下freemarker模板的加载门路,其实还有挺多默认的配置,然而只有这两行相干的配置就能满足广泛须要,如有特地的配置需要可到官网查看

源码地址:https://github.com/AsLightJav…

如有不分明或者遇到问题的,可上面留言分割我。


推荐阅读
  • 在springmvc框架中,前台ajax调用方法,对图片批量下载,如何弹出提示保存位置选框?Controller方法 ... [详细]
  • 本文介绍了在Python3中如何使用选择文件对话框的格式打开和保存图片的方法。通过使用tkinter库中的filedialog模块的asksaveasfilename和askopenfilename函数,可以方便地选择要打开或保存的图片文件,并进行相关操作。具体的代码示例和操作步骤也被提供。 ... [详细]
  • CEPH LIO iSCSI Gateway及其使用参考文档
    本文介绍了CEPH LIO iSCSI Gateway以及使用该网关的参考文档,包括Ceph Block Device、CEPH ISCSI GATEWAY、USING AN ISCSI GATEWAY等。同时提供了多个参考链接,详细介绍了CEPH LIO iSCSI Gateway的配置和使用方法。 ... [详细]
  • 分享css中提升优先级属性!important的用法总结
    web前端|css教程css!importantweb前端-css教程本文分享css中提升优先级属性!important的用法总结微信门店展示源码,vscode如何管理站点,ubu ... [详细]
  • 如何实现织梦DedeCms全站伪静态
    本文介绍了如何通过修改织梦DedeCms源代码来实现全站伪静态,以提高管理和SEO效果。全站伪静态可以避免重复URL的问题,同时通过使用mod_rewrite伪静态模块和.htaccess正则表达式,可以更好地适应搜索引擎的需求。文章还提到了一些相关的技术和工具,如Ubuntu、qt编程、tomcat端口、爬虫、php request根目录等。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 使用Ubuntu中的Python获取浏览器历史记录原文: ... [详细]
  • 本文介绍了计算机网络的定义和通信流程,包括客户端编译文件、二进制转换、三层路由设备等。同时,还介绍了计算机网络中常用的关键词,如MAC地址和IP地址。 ... [详细]
  • 在重复造轮子的情况下用ProxyServlet反向代理来减少工作量
    像不少公司内部不同团队都会自己研发自己工具产品,当各个产品逐渐成熟,到达了一定的发展瓶颈,同时每个产品都有着自己的入口,用户 ... [详细]
  • CentOS 6.5安装VMware Tools及共享文件夹显示问题解决方法
    本文介绍了在CentOS 6.5上安装VMware Tools及解决共享文件夹显示问题的方法。包括清空CD/DVD使用的ISO镜像文件、创建挂载目录、改变光驱设备的读写权限等步骤。最后给出了拷贝解压VMware Tools的操作。 ... [详细]
  • 本文介绍了一个适用于PHP应用快速接入TRX和TRC20数字资产的开发包,该开发包支持使用自有Tron区块链节点的应用场景,也支持基于Tron官方公共API服务的轻量级部署场景。提供的功能包括生成地址、验证地址、查询余额、交易转账、查询最新区块和查询交易信息等。详细信息可参考tron-php的Github地址:https://github.com/Fenguoz/tron-php。 ... [详细]
author-avatar
最棒小小丫_635
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有