SpringBoot-实现阅读数的增加功能(考虑并发)

考虑多用户同时访问的情况。

  1. 先创建一个自己的mapper配置文件xml
    QuestionExtMapper.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.july.community.mapper.QuestionExtMapperMapper">
    <resultMap id="BaseResultMap" type="com.july.community.model.Question">
        <constructor>
            <idArg column="id" javaType="java.lang.Integer" jdbcType="INTEGER" />
            <arg column="title" javaType="java.lang.String" jdbcType="VARCHAR" />
            <arg column="time_create" javaType="java.lang.Long" jdbcType="BIGINT" />
            <arg column="time_modified" javaType="java.lang.Long" jdbcType="BIGINT" />
            <arg column="creator" javaType="java.lang.Integer" jdbcType="INTEGER" />
            <arg column="comment_count" javaType="java.lang.Integer" jdbcType="INTEGER" />
            <arg column="view_count" javaType="java.lang.Integer" jdbcType="INTEGER" />
            <arg column="like_count" javaType="java.lang.Integer" jdbcType="INTEGER" />
            <arg column="tag" javaType="java.lang.String" jdbcType="VARCHAR" />
        </constructor>
    </resultMap>
    <resultMap id="ResultMapWithBLOBs" type="com.july.community.model.Question">
        <constructor>
            <idArg column="id" javaType="java.lang.Integer" jdbcType="INTEGER" />
            <arg column="title" javaType="java.lang.String" jdbcType="VARCHAR" />
            <arg column="time_create" javaType="java.lang.Long" jdbcType="BIGINT" />
            <arg column="time_modified" javaType="java.lang.Long" jdbcType="BIGINT" />
            <arg column="creator" javaType="java.lang.Integer" jdbcType="INTEGER" />
            <arg column="comment_count" javaType="java.lang.Integer" jdbcType="INTEGER" />
            <arg column="view_count" javaType="java.lang.Integer" jdbcType="INTEGER" />
            <arg column="like_count" javaType="java.lang.Integer" jdbcType="INTEGER" />
            <arg column="tag" javaType="java.lang.String" jdbcType="VARCHAR" />
            <arg column="description" javaType="java.lang.String" jdbcType="LONGVARCHAR" />
        </constructor>
    </resultMap>
    <update id="incView" parameterType="com.july.community.model.Question">
        update tbl_question set
        view_count = view_count + #{viewCount,jdbcType=INTEGER}
        where id = #{id}
    </update>
</mapper>
  1. 编写自己的mapper类
    QuestionExtMapper.java
package com.july.community.mapper;

import com.july.community.model.Question;

public interface QuestionExtMapper {
    int incView(Question record);
}
  1. 编写业务逻辑
package com.july.community.controller;
@GetMapping("question/{id}")
    public String question(@PathVariable(name = "id") Integer id,
                           Model model){

        QuestionDTO questionDTO =  questionService.getListById(id);
        //添加浏览数
        questionService.incView(id);
        model.addAttribute("question",questionDTO);
        return "question";
    }
package com.july.community.service;

@Autowired
    private QuestionExtMapper questionExtMapper;
    
public void incView(Integer id) {
        Question record = new Question();
        record.setId(id);
        record.setViewCount(1);
        questionExtMapper.incView(record);
    }
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值