您的位置:首页 > 娱乐 > 八卦 > 个人旅游网(4)——功能详解——收藏功能

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

2024/12/23 7:44:38 来源:https://blog.csdn.net/m0_63191002/article/details/141793029  浏览:    关键词:个人旅游网(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)、如果取消收藏操作失败,回滚事务。否则,取消收藏成功。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com