欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringBoot整合Mybatis-plus和Redis實現(xiàn)投票功能

 更新時間:2023年05月31日 10:26:51   作者:FeereBug  
投票功能是一個非常常見的Web應(yīng)用場景,這篇文章將為大家介紹一下如何將Redis和Mybatis-plus整合到SpringBoot中,實現(xiàn)投票功能,感興趣的可以了解一下

一、背景介紹

投票功能是一個非常常見的Web應(yīng)用場景,SpringBoot作為當(dāng)今流行的Web開發(fā)框架,為了提高開發(fā)效率和性能,通常需要整合一些第三方組件。Redis是一種高性能的鍵值對存儲數(shù)據(jù)庫,而Mybatis-plus則是Mybatis的擴展版本,提供了更強大和便捷的數(shù)據(jù)庫操作方式。本文將介紹如何將Redis和Mybatis-plus整合到SpringBoot中,實現(xiàn)投票功能。

二、開發(fā)環(huán)境

  • JDK 1.8
  • SpringBoot 2.5.0
  • Redis 6.2.4
  • Mybatis-plus 3.4.3
  • IntelliJ IDEA

三、技術(shù)實現(xiàn)

1. 配置Redis

在SpringBoot的配置文件application.yml中添加Redis的配置:

spring:
  # Redis相關(guān)配置
  redis:
    # Redis服務(wù)器IP地址
    host: localhost
    # Redis服務(wù)器端口號
    port: 6379
    # Redis服務(wù)器密碼
    password: 
    # Redis連接池最大連接數(shù)
    jedis:
      pool:
        max-active: 8
    # Redis連接池最大等待時間(單位:毫秒)
    lettuce:
      pool:
        max-wait: -1ms
    timeout: 5000ms

2. 配置Mybatis-plus

在SpringBoot的配置類中添加Mybatis-plus的配置:

@Configuration
@MapperScan("com.example.mapper")
public class MybatisPlusConfig {
    /**
     * Mybatis-plus分頁插件配置
     */
    @Bean
    public PaginationInterceptor paginationInterceptor() {
        return new PaginationInterceptor();
    }
    /**
     * Mybatis-plus通用Mapper配置
     */
    @Bean
    public MapperScannerConfigurer mapperScannerConfigurer() {
        MapperScannerConfigurer scannerConfigurer = new MapperScannerConfigurer();
        scannerConfigurer.setSqlSessionFactoryBeanName("sqlSessionFactory");
        scannerConfigurer.setBasePackage("com.example.mapper");
        return scannerConfigurer;
    }
}

3. 實現(xiàn)投票功能

首先創(chuàng)建一個投票的實體類Vote,包含投票項的id和投票數(shù)count:

@Data
@AllArgsConstructor
@NoArgsConstructor
public class Vote implements Serializable {
    private Long id;
    private Integer count;
}

然后創(chuàng)建投票的數(shù)據(jù)庫表vote,包含兩個字段id和count,id為主鍵:

CREATE TABLE `vote` (
  `id` bigint(20) NOT NULL,
  `count` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

接著創(chuàng)建投票的Mapper接口VoteMapper和對應(yīng)的XML文件VoteMapper.xml,定義增加投票數(shù)和查詢投票數(shù)的方法:

public interface VoteMapper extends BaseMapper<Vote> {
    /**
     * 增加投票數(shù)
     * @param id 投票項id
     * @return
     */
    int increaseCount(@Param("id") Long id);
    /**
     * 查詢投票數(shù)
     * @param id 投票項id
     * @return
     */
    int selectCount(@Param("id") Long id);
}
<?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.example.mapper.VoteMapper">
    <!-- 增加投票數(shù) -->
    <update id="increaseCount">
        update vote set count = count + 1
        where id = #{id}
    </update>
    <!-- 查詢投票數(shù) -->
    <select id="selectCount" resultType="int">
        select count
        from vote
        where id = #{id}
    </select>
</mapper>

接下來創(chuàng)建投票的Service類VoteService,其中增加投票數(shù)和查詢投票數(shù)的方法使用了Redis緩存:

@Service
public class VoteService {
    @Autowired
    private VoteMapper voteMapper;
    @Autowired
    private RedisTemplate<String, Object> redisTemplate;
    /**
     ** @param id 投票項id
     */
    public void increaseCount(Long id) {
        ValueOperations<String, Object> operations = redisTemplate.opsForValue();
        String key = "vote:" + id;
        // 先從緩存中獲取投票數(shù)
        Integer count = (Integer) operations.get(key);
        // 如果緩存中沒有,則從數(shù)據(jù)庫中獲取,并存入緩存
        if (count == null) {
            count = voteMapper.selectCount(id);
            if (count != null) {
                operations.set(key, count);
            }
        }
        // 如果緩存中有,則增加投票數(shù)并更新緩存
        if (count != null) {
            operations.increment(key);
            voteMapper.increaseCount(id);
        }
    }
    /**
     * 查詢投票數(shù)
     * @param id 投票項id
     * @return
     */
    public Integer selectCount(Long id) {
        ValueOperations<String, Object> operations = redisTemplate.opsForValue();
        String key = "vote:" + id;
        // 先從緩存中獲取投票數(shù)
        Integer count = (Integer) operations.get(key);
        // 如果緩存中沒有,則從數(shù)據(jù)庫中獲取,并存入緩存
        if (count == null) {
            count = voteMapper.selectCount(id);
            if (count != null) {
                operations.set(key, count);
            }
        }
        return count;
    }
}

最后創(chuàng)建投票的Controller類VoteController,提供增加投票數(shù)和查詢投票數(shù)的接口:

@RestController
public class VoteController {
    @Autowired
    private VoteService voteService;
    /**
     * 增加投票數(shù)接口
     * @param id 投票項id
     * @return
     */
    @PostMapping("/vote/increase")
    public String increaseCount(@RequestParam Long id) {
        voteService.increaseCount(id);
        return "success";
    }
    /**
     * 查詢投票數(shù)接口
     * @param id 投票項id
     * @return
     */
    @GetMapping("/vote/select")
    public Integer selectCount(@RequestParam Long id) {
        Integer count = voteService.selectCount(id);
        return count == null ? 0 : count;
    }
}

四、測試運行

啟動SpringBoot應(yīng)用后,在瀏覽器中訪問http://localhost:8080/vote/select?id=1,可以查詢id為1的投票項的投票數(shù);再訪問http://localhost:8080/vote/increase?id=1,可以對id為1的投票項進行投票。同時可以在Redis客戶端中查看投票項的投票數(shù)是否正確。

五、總結(jié)

本文介紹了如何將Redis和Mybatis-plus整合到SpringBoot中,以實現(xiàn)投票功能。其中Redis緩存可以增加應(yīng)用性能,Mybatis-plus可以簡化數(shù)據(jù)庫操作。代碼已上傳至Github:https://github.com/chatbot-ai/spring-boot-redis-mybatis-vote

到此這篇關(guān)于SpringBoot整合Mybatis-plus和Redis實現(xiàn)投票功能的文章就介紹到這了,更多相關(guān)SpringBoot Redis投票內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:

相關(guān)文章

  • 在K8s上部署Redis集群的方法步驟

    在K8s上部署Redis集群的方法步驟

    這篇文章主要介紹了在K8s上部署Redis集群的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • redis延時隊列zset實現(xiàn)的示例

    redis延時隊列zset實現(xiàn)的示例

    延時隊列是一種常用的設(shè)計模式,用于處理那些需要在未來某個時間點執(zhí)行的任務(wù),本文主要介紹了redis延時隊列zset實現(xiàn)的示例,具有一定的參考價值,感興趣的可以了解一下
    2024-08-08
  • 在CenOS系統(tǒng)下安裝和配置Redis數(shù)據(jù)庫的教程

    在CenOS系統(tǒng)下安裝和配置Redis數(shù)據(jù)庫的教程

    這篇文章主要介紹了在CenOS系統(tǒng)下安裝和配置Redis數(shù)據(jù)庫的教程,Redis是一個可基于內(nèi)存的高性能NoSQL數(shù)據(jù)庫,需要的朋友可以參考下
    2015-11-11
  • Redis?key-value亂碼的解決

    Redis?key-value亂碼的解決

    本文主要介紹了Redis?key-value亂碼的解決,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • Redis過期刪除策略與內(nèi)存淘汰策略

    Redis過期刪除策略與內(nèi)存淘汰策略

    這篇文章主要介紹了Redis過期刪除策略與內(nèi)存淘汰策略,文章圍繞主題展開詳細(xì)的內(nèi)容戒殺,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-09-09
  • Redis SETNX的實現(xiàn)示例

    Redis SETNX的實現(xiàn)示例

    SETNX是Redis提供的原子操作,用于在指定鍵不存在時設(shè)置鍵值,并返回操作結(jié)果,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-12-12
  • WINDOWS中REDIS主從配置實現(xiàn)代碼解析

    WINDOWS中REDIS主從配置實現(xiàn)代碼解析

    這篇文章主要介紹了WINDOWS中REDIS主從配置實現(xiàn)代碼解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-08-08
  • 阿里云服務(wù)器安裝配置redis的方法并且加入到開機啟動(推薦)

    阿里云服務(wù)器安裝配置redis的方法并且加入到開機啟動(推薦)

    這篇文章主要介紹了阿里云服務(wù)器安裝配置redis并且加入到開機啟動,需要的朋友可以參考下
    2017-12-12
  • 保證Redis中存儲的Token安全性的示例詳解

    保證Redis中存儲的Token安全性的示例詳解

    確保Redis中存儲的Token安全性是一個多層面的任務(wù),涉及到網(wǎng)絡(luò)、應(yīng)用、數(shù)據(jù)和操作等多個方面的安全措施,本文給大家介紹了一些詳細(xì)的實踐建議和示例,并有詳細(xì)的代碼供大家參考,需要的朋友可以參考下
    2024-03-03
  • 玩轉(zhuǎn)Redis搭建集群之Sentinel詳解

    玩轉(zhuǎn)Redis搭建集群之Sentinel詳解

    這篇文章主要給大家介紹了關(guān)于Redis搭建集群之Sentinel的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-11-11

最新評論