文章目錄
- 業務描述
- 準備作業
- 初始化資料
- 添加專案依賴
- 添加資料庫訪問配置
- 業務邏輯代碼設計及實作
- Domain物件設計
- Dao 邏輯物件設計
- Service 邏輯物件設計
- Controller邏輯物件設計
- 總結(Summary)
業務描述
從一個博客資料庫中查詢所有的文章標簽,然后存盤到快取(Cache),后續查詢時可從快取獲取,提高其查詢性能,
準備作業
初始化資料
初始化資料庫中資料,SQL腳本如下:
DROP DATABASE IF EXISTS `blog`;
CREATE DATABASE `blog` DEFAULT character set utf8mb4;
SET names utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;
USE `blog`;
CREATE TABLE `tb_tag` (
`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',
`name` varchar(255) NOT NULL COMMENT 'data_id',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='tb_tag';
insert into `tb_tag` values (null,"mysql"),(null,"redis");
添加專案依賴
在jt-template工程的原有依賴基礎上添加mysql資料庫訪問依賴,例如:
<!--mysql-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
<!--mybatis-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.4.2</version>
</dependency>
添加資料庫訪問配置
在專案的組態檔(例如application.yml)中添加資料庫訪問配置,例如:
spring:
datasource:
url: jdbc:mysql:///blog?serverTimezone=Asia/Shanghai&characterEncoding=utf8
username: root
password: root
業務邏輯代碼設計及實作
Domain物件設計
創建一個Tag類,基于此型別的物件存盤Tag(標簽資訊),代碼如下:
package com.jt.blog.domain;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import java.io.Serializable;
/**
* 標簽類的設計
*/
@TableName("tb_tag")
public class Tag implements Serializable {
private static final long serialVersionUID = 4504013456197711455L;
/**標簽id*/
@TableId(type = IdType.AUTO)
private Long id;
/**標簽名*/
private String name;
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "Tag{" +
"id=" + id +
", name='" + name + '\'' +
'}';
}
}
Dao 邏輯物件設計
創建Tag資訊的資料訪問介面,代碼如下:
package com.jt.blog.dao;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.jt.blog.domain.Tag;
import org.apache.ibatis.annotations.Mapper;
@Mapper
public interface TagMapper
extends BaseMapper<Tag> {
}
創建單元測驗類,TagMapper中的相關方法進行單元測驗,例如:
package com.jt.blog.dao;
import com.jt.blog.domain.Tag;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import java.util.List;
@SpringBootTest
public class TagMapperTests {
@Autowired
private TagMapper tagMapper;
@Test
void testSelectList(){
List<Tag> tags =
tagMapper.selectList(null);
for(Tag t:tags){
System.out.println(t);
//System.out.println(t.getId()+"/"+t.getName());
}
}
}
Service 邏輯物件設計
設計TagService介面及實作類,定義Tag(標簽)業務邏輯,
第一步:定義TagService介面,代碼如下:
package com.jt.blog.service;
import com.jt.blog.domain.Tag;
import java.util.List;
public interface TagService {
/**
* 查詢所有的標簽
* @return
*/
List<Tag> selectTags();
}
第二步:定義TagServiceImpl類,代碼如下:
package com.jt.blog.service.impl;
import com.jt.blog.dao.TagMapper;
import com.jt.blog.domain.Tag;
import com.jt.blog.service.TagService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.core.ValueOperations;
import org.springframework.stereotype.Service;
import java.util.List;
@Service
public class TagServiceImpl implements TagService {
//RedisAutoConfiguration 類中做的RedisTemplate的配置
@Autowired
private RedisTemplate redisTemplate;
@Autowired
private TagMapper tagMapper;
@Override
public List<Tag> selectTags() {
//1.從redis查詢Tag資訊,redis有則直接回傳
ValueOperations<String,List<Tag>> valueOperations =
redisTemplate.opsForValue();
List<Tag> tags=valueOperations.get("tags");
if(tags!=null&&!tags.isEmpty())return tags;
//2.從redis沒有獲取tag資訊,查詢mysql
tags = tagMapper.selectList(null);
//3.將從mysql查詢到tag資訊存盤到redis
valueOperations.set("tags", tags);
//4.回傳查詢結果
return tags;
}
}
說明,假如將List存盤到redis,此時Tag必須實作Serializable介面,
第三步:定義TagServiceTests單元測驗類并進行單元測驗,代碼如下:
package com.jt.blog.service;
import com.jt.blog.domain.Tag;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import java.util.List;
@SpringBootTest
public class TagServiceTests {
@Autowired
private TagService tagService;
@Test
void testSelectTags(){
List<Tag> tags=
tagService.selectTags();
System.out.println(tags);
}
}
Controller邏輯物件設計
創建Tag控制邏輯物件,用于處理請求和回應邏輯,代碼如下:
package com.jt.blog.controller;
import com.jt.blog.domain.Tag;
import com.jt.blog.service.TagService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.ArrayList;
import java.util.List;
@RestController
@RequestMapping("/tag")
public class TagController {
@Autowired
private TagService tagService;
@GetMapping
public List<Tag> doSelectTags(){
return tagService.selectTags());//1.redis,2.mysql
}
}
啟動服務,打開瀏覽器進行訪問測驗,同時思考,我們是否可以在這個層加一個本地cache,
總結(Summary)
本章節重點是學習專案中快取(Cache)的一種應用思想,
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/312115.html
標籤:java
上一篇:Java面向物件基礎
