旅游项目day07

目的地攻略展示

根据目的地和主题查询攻略

攻略条件查询

攻略排行分析

  • 推荐排行榜:点赞数+收藏数 取前十名

  • 热门排行榜:评论数+浏览数 取前十名 浏览数跟评论数差距过大,可设置不同权重,例如:将浏览数权重设置为0.3,评论数权重设置为0.7。

    如果是小表,以上的sql没太大问题。
    但是,,如果表的数据量非常大?
    排序,运算会导致mysql性能大大降低。
    如何解决性能问题?
  • mysql性能优化。
    1. 给需要排序的字段,加索引

      但是,对索引列做任何运算,(concat + - * /)等操作,都会导致索引失效,仍会出现性能问题。

      但是因为必须要用到的算法,所以必须要做运算。如何解决?如何优化?
      不实时! 排行榜不是实时更新,比如半个小时更新一次。

      把实时查询的数据,变成不实时的数据。

      半个小时查询一次后,将数据放到另外一张表,或者放到redis。

      优化方案:将原本实时查询的数据,变成每10分钟统计一次,将统计后的数据放到一张更新的表中,之后查询排行榜信息时,直接查询新的表即可。

      新的表如何设计?

      id,dest_id,dest_name,strategy_id,strategy_title,num,type,status_time

      统计数量 统计时间

      如何实现每10分钟去做一个事情?
      定时任务。

      定时统计方案:

      1. TimerTask | ScheduledThreadPoolExecutor:JDK自带的定时任务类 不支持分布式

      2. Spring Scheduled:任务调度组件,quartz

      3. 分布式任务调度组卷:xxl-job,elastic-job 需要引入额外的服务

      如何抉择?
      Spring的定时任务。

      Spring定时任务示例代码:每个两秒打印一次时间

      每隔一段时间。

      需要新创建一个服务。为什么?

      如果在文章服务开启定时任务,会导致占用一定的cpu,对性能有一定的影响。

      故新创建一个数据服务(travel-data-server)。新建一个定时任务类,@Component交给Spring容器管理。

      启动类加@EnableScheduling

      定时任务类方法加@Scheduled()注解。

      corn表达式,是linux里面的一个机制。秒,分钟,小时,月中某日,月,周中某日

      corn表达式口诀: "秒分时日月周"

bash 复制代码
Cron表达式用于指定计划任务(如在Unix、Linux和Spring框架中的定时任务)的执行时间。
要创建一个在每个工作日(星期一到星期五)凌晨两点执行的Cron表达式,你可以使用以下格式:

0 2 * * 1-5

这个表达式的各部分意义如下:

- `0` 分钟:表示在小时的开始时刻(即每小时的第0分钟)。
- `2` 小时:表示凌晨2点。
- `*` 日:表示每天。
- `*` 月:表示每个月。
- `1-5` 星期:表示星期一到星期五。

所以,这个Cron表达式代表着"在每个月的每天,
如果是星期一到星期五,那么在凌晨2点执行任务"。这正符合你的要求。

示例:


不一定非要去琢磨透corn表达式,工具是为我们提高效率而服务的,可借助corn表达式生成工具去生成。

实现:

改写为函数式编程:

如何排序?

相关推荐
李慕婉学姐20 小时前
Springboot智慧旅游管理系统6w63eon8(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·旅游
GIS数据转换器20 小时前
基于GIS的智慧旅游调度指挥平台
运维·人工智能·物联网·无人机·旅游·1024程序员节
JIngJaneIL20 小时前
旅游|内蒙古景点旅游|基于Springboot+Vue的内蒙古景点旅游管理系统设计与实现(源码+数据库+文档)
java·vue.js·spring boot·论文·旅游·毕设·内蒙古景点旅游
傻啦嘿哟20 小时前
旅游网站爬虫实战:抓取携程酒店价格趋势全解析
爬虫·旅游
毕设源码-朱学姐1 天前
【开题答辩全过程】以 基于Vue.js和Node.js的在线旅游平网站的设计和实现为例,包含答辩的问题和答案
旅游
keke.shengfengpolang2 天前
中专旅游管理专业职业发展指南:从入门到精通的成长路径
人工智能·旅游
大菠萝学姐4 天前
基于springboot的旅游攻略网站设计与实现
前端·javascript·vue.js·spring boot·后端·spring·旅游
九章-4 天前
中旅国际数据库国产化升级:以金仓KES打造安全可控的旅游服务底座
数据库·安全·旅游
机器学习之心6 天前
MATLAB基于变权理论和灰色云模型的海岛旅游地生态安全评价
安全·matlab·旅游·灰色云模型
一 乐7 天前
旅游|内蒙古景点旅游|基于Springboot+Vue的内蒙古景点旅游管理系统设计与实现(源码+数据库+文档)
开发语言·前端·数据库·vue.js·spring boot·后端·旅游