【Spring Boot】初识Spring Boot之开发博客项目(七)

编写归档

按照博客的年份来分类博客
在这里插入图片描述
IndexController

@GetMapping("archives")
    public String archives(Model model){
        Long count=blogService.countBlog();//获取总数
        Map<String,List<Blog>> blogs=blogService.archivesBlog();//查询博客

        model.addAttribute("blogCount",count);
        model.addAttribute("archiveMap",blogs);
        return "archives";
    }

IBlogService

	Long countBlog();

    Map<String, List<Blog>> archivesBlog();

BlogServiceImpl

@Override
    public Long countBlog() {
        return blogDao.count();
    }

    @Override
    public Map<String, List<Blog>> archivesBlog() {
        List<String> year = blogDao.findGroupYear();
        Map<String, List<Blog>> map=new HashMap<>();
        for(String y:year){
            List<Blog> blogs=blogDao.findByYear(y);
            map.put(y,blogs);
        }

        return map;
    }

BlogDao
在BlogDao中写 findGroupYear()、findByYear(String y)根据年份查找、根据年份分组的方法。

@Query("select function('date_format',b.updateTime,'%Y') as year from Blog  b group by year order by year desc")
    List<String> findGroupYear();

    @Query("select b from Blog b where function('date_format',b.updateTime,'%Y') = ?1")
    List<Blog> findByYear(String y);

以新增19年test为例
在这里插入图片描述

关于我

在这里插入图片描述
IndexController

@RequestMapping("about")
    public String about(){
        return "about";
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值