个人旅游网(4)——功能详解——收藏功能

2024-09-02 09:12

本文主要是介绍个人旅游网(4)——功能详解——收藏功能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 一、收藏排行榜功能
    • 1.1、接口详解
      • 1.1.1、findRouteList
  • 二、收藏功能
    • 2.1、接口详解
      • 2.1.1、find(用于判断当前旅游路线是否已被收藏)
      • 2.1.2、add-favorite(用于实现收藏功能)
      • 2.1.3、remove-favorite(用于实现取消收藏的功能)

一、收藏排行榜功能

收藏排行榜页面效果图:
在这里插入图片描述
该功能主要由一个接口 findRouteList 完成,在此接口中需要完成所有旅游线路的查询、模糊搜索、分页这3个功能。

1.1、接口详解

1.1.1、findRouteList

(1)、首先需要设置好当前页面的分页条件
当前页面我以每页8条数据,并且是以旅游路线的名称作为分页。

//设置分页条件PageHelper.startPage(favoriteDTO.getPageNum(),8);

(2)、查询所有的旅游路线数据
由于前端传过来的参数是以json格式组织的,因此定义一个 FavoriteDTO 类,里面存储从前端传过来的多个参数。findRoutes() 是从数据库中查询出所有的旅游路线数据。

//查询数据List<Route> routeList = this.routeMapper.findRoutes(favoriteDTO);

(3)、编写数据库中的sql语句
在这里插入图片描述
在这里插入图片描述

二、收藏功能

页面效果图:
在这里插入图片描述
在这里插入图片描述
收藏功能一共涉及 3 个接口,分别是 find(与 isLogged接口的作用类似,用于判断当前旅游路线是否已被收藏)、add-favorite(用于实现收藏功能)、remove-favorite(用于实现取消收藏的功能)。外加一个辅助的方法 updateFavoriteNum() ,该方法用于实现收藏功能时上坪旅游路线的收藏数+1的功能。

2.1、接口详解

2.1.1、find(用于判断当前旅游路线是否已被收藏)

前端传入一个 rid 参数,后端接收此参数,并根据 rid 从数据库的favorite表中查询数据,如果 Favorite 对象存在,说明该旅游路线已被收藏;如果Favorite 对象不存在,说明该旅游路线未被收藏。
在这里插入图片描述

2.1.2、add-favorite(用于实现收藏功能)

(1)、首先根据rid从数据库中查询Favorite对象,如果Favorite对象为空,说明当前用户之前未对该旅游路线进行过收藏,可以进行收藏操作,新增(save)一个 Favorite 对象,如果Favorite对象不为空,抛出一个 不可重复收藏的异常,阻止用户进行重复收藏操作。

(2)、借助updateFavoriteNum() 进行收藏操作。该方法首先通过rid在数据库中查询 Route对象,从Route对象中获取当前旅游路线的收藏次数,使用 update 语句将 Route 对象中的收藏次数修改为 收藏次数 + 1,即可完成收藏操作。

(3)、判断新增操作的受影响行数,如果受影响行数row 为0,说明收藏失败,回滚事务。否则,收藏成功。

2.1.3、remove-favorite(用于实现取消收藏的功能)

(1)、首先根据rid从数据库中查询Favorite对象,如果Favorite对象不为空,说明当前用户之前已对该旅游路线进行过收藏,可以进行取消收藏操作,删除(delete)对于 rid、uid下的 Favorite 对象,如果Favorite对象为空,抛出一个 不可重复取消收藏的异常,阻止用户进行重复取消收藏操作。

(2)、借助updateFavoriteNum() 进行取消收藏操作。该方法首先通过rid在数据库中查询 Route对象,从Route对象中获取当前旅游路线的收藏次数,使用 delete 语句将 Route 对象中的收藏次数修改为 收藏次数 - 1,即可完成取消收藏操作。

(3)、如果取消收藏操作失败,回滚事务。否则,取消收藏成功。

这篇关于个人旅游网(4)——功能详解——收藏功能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1129572

相关文章

pycharm远程连接服务器运行pytorch的过程详解

《pycharm远程连接服务器运行pytorch的过程详解》:本文主要介绍在Linux环境下使用Anaconda管理不同版本的Python环境,并通过PyCharm远程连接服务器来运行PyTorc... 目录linux部署pytorch背景介绍Anaconda安装Linux安装pytorch虚拟环境安装cu

一文详解如何在Python中使用Requests库

《一文详解如何在Python中使用Requests库》:本文主要介绍如何在Python中使用Requests库的相关资料,Requests库是Python中常用的第三方库,用于简化HTTP请求的发... 目录前言1. 安装Requests库2. 发起GET请求3. 发送带有查询参数的GET请求4. 发起PO

Python进行PDF文件拆分的示例详解

《Python进行PDF文件拆分的示例详解》在日常生活中,我们常常会遇到大型的PDF文件,难以发送,将PDF拆分成多个小文件是一个实用的解决方案,下面我们就来看看如何使用Python实现PDF文件拆分... 目录使用工具将PDF按页数拆分将PDF的每一页拆分为单独的文件将PDF按指定页数拆分根据页码范围拆分

Java中的Cursor使用详解

《Java中的Cursor使用详解》本文介绍了Java中的Cursor接口及其在大数据集处理中的优势,包括逐行读取、分页处理、流控制、动态改变查询、并发控制和减少网络流量等,感兴趣的朋友一起看看吧... 最近看代码,有一段代码涉及到Cursor,感觉写法挺有意思的。注意是Cursor,而不是Consumer

SpringBoot项目注入 traceId 追踪整个请求的日志链路(过程详解)

《SpringBoot项目注入traceId追踪整个请求的日志链路(过程详解)》本文介绍了如何在单体SpringBoot项目中通过手动实现过滤器或拦截器来注入traceId,以追踪整个请求的日志链... SpringBoot项目注入 traceId 来追踪整个请求的日志链路,有了 traceId, 我们在排

HTML5中下拉框<select>标签的属性和样式详解

《HTML5中下拉框<select>标签的属性和样式详解》在HTML5中,下拉框(select标签)作为表单的重要组成部分,为用户提供了一个从预定义选项中选择值的方式,本文将深入探讨select标签的... 在html5中,下拉框(<select>标签)作为表单的重要组成部分,为用户提供了一个从预定义选项中

Python中多线程和多进程的基本用法详解

《Python中多线程和多进程的基本用法详解》这篇文章介绍了Python中多线程和多进程的相关知识,包括并发编程的优势,多线程和多进程的概念、适用场景、示例代码,线程池和进程池的使用,以及如何选择合适... 目录引言一、并发编程的主要优势二、python的多线程(Threading)1. 什么是多线程?2.

MobaXterm远程登录工具功能与应用小结

《MobaXterm远程登录工具功能与应用小结》MobaXterm是一款功能强大的远程终端软件,主要支持SSH登录,拥有多种远程协议,实现跨平台访问,它包括多会话管理、本地命令行执行、图形化界面集成和... 目录1. 远程终端软件概述1.1 远程终端软件的定义与用途1.2 远程终端软件的关键特性2. 支持的

Java 8 Stream filter流式过滤器详解

《Java8Streamfilter流式过滤器详解》本文介绍了Java8的StreamAPI中的filter方法,展示了如何使用lambda表达式根据条件过滤流式数据,通过实际代码示例,展示了f... 目录引言 一.Java 8 Stream 的过滤器(filter)二.Java 8 的 filter、fi

Java中实现订单超时自动取消功能(最新推荐)

《Java中实现订单超时自动取消功能(最新推荐)》本文介绍了Java中实现订单超时自动取消功能的几种方法,包括定时任务、JDK延迟队列、Redis过期监听、Redisson分布式延迟队列、Rocket... 目录1、定时任务2、JDK延迟队列 DelayQueue(1)定义实现Delayed接口的实体类 (