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

一、收藏排行榜功能

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

1.1、接口详解

1.1.1、findRouteList

(1)、首先需要设置好当前页面的分页条件
当前页面我以每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)、如果取消收藏操作失败,回滚事务。否则,取消收藏成功。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值