一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Spring Boot設置并使用緩存的步驟

Spring Boot設置并使用緩存的步驟

2019-06-21 14:47Codenjoyes Java教程

今天小編就為大家分享一篇關于Spring Boot設置并使用緩存的步驟,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧

幾個緩存注解的作用:

@Cacheable:將方法的返回結果根據key指定的鍵保存在緩存中,以后要獲取相同的數據直接從緩存中共獲取

  • cacheNames/value:指定Cache組件名稱
  • key:指定緩存時使用的key,默認使用方法參數值,可以使用#a0、#p0、#參數名等,支持SpEL表達式,root可省略
  • keyGenerator:指定key的生成器的組件id,如自定義的KeyGenerator
  • cacheManager:指定緩存管理器
  • cacheResolver:指定緩存解析器
  • condition:指定在哪種條件下緩存,如condition = “#id>=1”在參數>=1時緩存
  • unless:指定該條件為真時不緩存
  • sync:指定是否使用異步模式

@CachePut:不管緩存中是否有需要的數據,都會執行該注解標注的方法,并將結果更新到緩存,屬性見上

@CacheEvit:執行方法后,清除key指定的緩存

  • allEntries:默認為false,值為true,刪除所有緩存
  • beforeInvocation:默認為false,值為true,在方法調用之前清除緩存

@CacheConfig:定義一些通用或公共的規則,如cacheNames、keyGenerator等

可使用的SpEL表達式:

Spring Boot設置并使用緩存的步驟

使用緩存的步驟:

(1)創建一個Spring Boot應用,勾選Cache、Web、MySQL、Mybatis模塊,在主程序類上添加注解,開啟基于注解的緩存

@MapperScan(basePackages = "com.youngpain.cache.mapper")
@SpringBootApplication
@EnableCaching

(2)創建JavaBean,和數據庫中的表對應,并配置數據源

spring:
 datasource:
  url: jdbc:mysql://localhost:3306/mybatis_database
  username: root
  password: 1741248769
  driver-class-name: com.mysql.jdbc.Driver
 redis:
  host: 39.108.114.57
#開啟駝峰命名法
mybatis:
 configuration:
  map-underscore-to-camel-case: true
logging:
 level:
  com.youngpain.cache.mapper: debug

(3)創建mapper接口進行增刪改查操作

/**
 * 部門表的增刪改查操作
 */
public interface DepartmentMapper {
  @Insert("insert into department(id,depart_name,depart_build) values(#{id},#{depart_name},#{depart_build})")
  void insertDepartment(Department department);
  @Delete("delete from department where id=#{id}")
  void deleteDepartment(Integer id);
  @Update("update department set depart_name=#{departName},depart_build=#{departBuild} where id=#{id}")
  void updateDepartment(Department department);
  @Select("select * from department where id=#{id}")
  Department getDepartmentById(Integer id);
}

(4)創建service

@Service
@CacheConfig(cacheNames = {"departs"})
public class DepartmentService {
  @Autowired
  DepartmentMapper departmentMapper;
  @Cacheable(key = "#a0.id")
  public void insertDepartment(Department department) {
    departmentMapper.insertDepartment(department);
  }
  @CacheEvict(key = "#p0")
  public void deleteDepartment(Integer id) {
    departmentMapper.deleteDepartment(id);
  }
  @CachePut(key = "#a0.id")
  public Department updateDepartment(Department department) {
    departmentMapper.updateDepartment(department);
    return department;
  }
  @Cacheable(key = "#id", condition = "#p0>=1")
  public Department getDepartmentById(Integer id) {
    return departmentMapper.getDepartmentById(id);
  }
}

(5)創建controller

@Controller
public class DepartmentController {
  @Autowired
  DepartmentService departmentService;
  @GetMapping("/index")
  public String index() {
    return "index";
  }
  @GetMapping("/deleteDepart/{id}")
  public String deleteDepart(@PathVariable("id") Integer id, Model model) {
    model.addAttribute("condition", "delete");
    Department delete = departmentService.getDepartmentById(id);
    model.addAttribute("department", delete);
    departmentService.deleteDepartment(id);
    return "success";
  }
  @PostMapping("/updateDepart")
  public String updateDepart(Department department, Model model) {
    model.addAttribute("condition", "update");
    Department update = departmentService.updateDepartment(department);
    model.addAttribute("department", update);
    return "success";
  }
  @GetMapping("/getDepart/{id}")
  public String getDepartmentById(@PathVariable("id") Integer id, Model model) {
    model.addAttribute("condition", "delete");
    Department get = departmentService.getDepartmentById(id);
    model.addAttribute("department", get);
    return "success";
  }
}

(6)測試結果:

@Cacheable:第一次查詢數據,控制臺發出sql語句,之后再查詢直接從緩存中獲取
@CachePut:調用方法修改某個數據后,再次查詢該數據是從緩存中獲取的更新后的數據
@CacheEvict:調用該方法后,再次查詢某個數據需要重新發出sql語句查詢

ps:之前只是用markdown記筆記,今天第一次用markdown寫文章,寫起來好舒服啊QAQ

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對服務器之家的支持。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 男人女人叉叉叉 | www.男人的天堂 | 好男人资源免费观看 | 国产亚洲精品第一综合linode | 久久久免费观看 | 日韩无遮挡大尺度啪啪影片 | 国产精品福利短视在线播放频 | 护士xxxx| 图片亚洲va欧美va国产综合 | 免费观看www视频 | 日本一区二区免费在线 | 草草免费观看视频在线 | 日本中文字幕永久在线 | 兽操人 | 99视频有精品视频免费观看 | 白丝尤物的下面被疯狂蹂躏 | 高清国产精品久久久久 | 99热免费在线观看 | sihu国产午夜精品一区二区三区 | 亚洲一级特黄特黄的大片 | 亚洲另类中文字幕 | 麻豆视频免费在线播放 | 任我行视频在线观看国语 | 精品国产国偷自产在线观看 | 女暴露狂校园裸露小说 | 精品国产欧美一区二区三区成人 | 美女扒开奶罩让男人吃奶 | 114级毛片免费观看 1024亚洲天堂 | 免费一级欧美大片在线观看 | 美女禁区视频免费观看精选 | 日日操日日舔 | 亚洲国产五月综合网 | 精品国产成人高清在线 | 大陆国产精品视频 | 双性np肉文 | 大学生初次破苞免费视频 | 毛茸茸的大逼 | 国语自产拍在线播放不卡 | 羞羞视频免费观看网站 | 亚洲天堂视频在线播放 | 欧美国产在线观看 |