基于Spring Boot+Vue的博客系统 08——数据库访问

废弃说明:
这个专栏的文章本意是记录笔者第一次搭建博客的过程,文章里里有很多地方的写法都不太恰当,现在已经废弃,关于SpringBoot + Vue 博客系列,笔者重新写了这个系列的文章,不敢说写的好,但是至少思路更加清晰,还在看SpringBoot + Vue 博客系列文章的朋友可以移步:https://blog.csdn.net/li3455277925/category_10341110.html,文章中有错误的地方或者大家有什么意见或建议都可以评论或者私信交流。

0. 实体类设计
  • 新建com.qianyucc.blog.model.entity.ArticleDO对应数据库中文章表
package com.qianyucc.blog.model.entity;

import lombok.*;

import javax.persistence.*;

/**
 * @author lijing
 * @date 2019-10-11 10:10
 * @description 对应数据库中article表
 */
@Data
@Entity
@Table(name = "article")
public class ArticleDO {
    @javax.persistence.Id
    // 主键自增
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;
    @Column(name = "author", nullable = false, length = 20)
    private String author;
    @Column(name = "title", length = 100)
    private String title;
    @Column(name = "content", columnDefinition = "clob not null")
    private String content;
    @Column(name = "tags", length = 50)
    private String tags;
    private Integer type;
    @Column(name = "category", length = 50)
    private String category;
    @Column(name = "gmt_create")
    private Long gmtCreate;
    @Column(name = "gmt_update")
    private Long gmtUpdate;
    private String tabloid;
    private Integer comments;
    private Integer views;
}
  • 字段含义:
字段名称字段含义
id主键
author文章作者
title文章标题
content文章内容,markdown格式
tags文章标签,多个标签使用英文逗号隔开
type文章类型(1为原创,0位转载)
category文章类别
gmtCreate文章创建时间
gmtUpdate文章更新时间
tabloid文章摘要
comments文章评论数
views文章浏览数
  • 新建com.qianyucc.blog.model.entity.UserDO类,对应数据库中的用户表
package com.qianyucc.blog.model.entity;

import lombok.*;

import javax.persistence.*;

/**
 * @author lijing
 * @date 2019-10-11 10:21
 * @description 对应数据库中用户表
 */
@Data
@Entity
@Table(name = "user")
public class UserDO {
    @Id
    private Long id;
    @Column(name = "name", length = 20)
    private String name;
    @Column(name = "login", length = 50)
    private String login;
    @Column(name = "avatar_url")
    private String avatarUrl;
    private String bio;
    private String token;
    @Column(name = "gmt_create")
    private Long gmtCreate;
    @Column(name = "gmt_update")
    private Long gmtUpdate;
}
  • 字段含义
字段名称字段含义
id主键
name用户昵称
login用户名
avatarUrl头像链接
bio用户描述
token用户登录标识
gmtCreate用户第一次登录时间
gmtUpdate用户最近登录时间
  • 新建com.qianyucc.blog.model.entity.CommentDO类,对应数据库中评论表
package com.qianyucc.blog.model.entity;

import lombok.*;

import javax.persistence.*;

/**
 * @author lijing
 * @date 2019-10-11 10:29
 * @description 对应数据库中评论表
 */
@Data
@Entity
@Table(name = "comment")
public class CommentDO {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;
    @Column(name = "parent_id")
    private Long parentId;
    // 1表示文章评论,2表示二级评论
    private Integer type;
    private Long commentator;
    @Column(name = "content", columnDefinition = "clob not null")
    private String content;
    @Column(name = "gmt_create")
    private Long gmtCreate;
    @Column(name = "gmt_update")
    private Long gmtUpdate;
    private Long likes;
    private Long comments;
}
  • 字段含义
字段名称字段含义
id主键
parentId父级id,如果为文章评论就为文章id,如果为二级评论就为一级评论的id
type评论类型( 1表示文章评论,2表示二级评论)
commentator评论人id,匿名用户id为0L
content评论内容
gmtCreate评论创建时间
gmtUpdate评论更新时间
likes评论点赞数
comments评论的评论数
1. 创建数据库访问层
  • 新建com.qianyucc.blog.repository.UserRepository接口,com.qianyucc.blog.repository.CommentRepository接口,com.qianyucc.blog.repository.ArticleRepository接口分别继承JpaRepositoryJpaSpecificationExecutor接口,之后就有了CRUD的功能
package com.qianyucc.blog.repository;

import com.qianyucc.blog.model.entity.*;
import org.springframework.data.jpa.repository.*;

/**
 * @author lijing
 * @date 2019-10-11 10:39
 * @description 访问数据库中文章
 */
public interface ArticleRepository extends JpaRepository<ArticleDO, Long>, JpaSpecificationExecutor<ArticleDO> {
}
package com.qianyucc.blog.repository;

import com.qianyucc.blog.model.entity.*;
import org.springframework.data.jpa.repository.*;

/**
 * @author lijing
 * @date 2019-10-11 10:40
 * @description 访问数据库中评论
 */
public interface CommentRepository extends JpaRepository<CommentDO, Long>, JpaSpecificationExecutor<CommentDO> {
}
package com.qianyucc.blog.repository;

import com.qianyucc.blog.model.entity.*;
import org.springframework.data.jpa.repository.*;

/**
 * @author lijing
 * @date 2019-10-11 10:41
 * @description 访问数据库中用户
 */
public interface UserRepository extends JpaRepository<UserDO, Long>, JpaSpecificationExecutor<UserDO> {
}

2.创建测试Controller
  • 新建com.qianyucc.blog.controller.comm.TestController用于测试
  • 这里顺便推荐一款插件:GenerateAllSetter,安装插件之后使用Alt+Enter就可以自动调出所有的setter方法,效果如下:

自动调出setter

package com.qianyucc.blog.controller.comm;

import com.qianyucc.blog.model.entity.*;
import com.qianyucc.blog.repository.*;
import org.springframework.beans.factory.annotation.*;
import org.springframework.web.bind.annotation.*;

import java.util.*;

/**
 * @author lijing
 * @date 2019-10-11 11:06
 * @description 控制器测试
 */
@RestController
public class TestController {
    @Autowired
    private ArticleRepository articleRepository;

    @GetMapping("/ins")
    public String ins() {
        ArticleDO articleDO = new ArticleDO();
        articleDO.setId(0L);
        articleDO.setAuthor("qianyu");
        articleDO.setTitle("How to learn SpringBoot");
        articleDO.setContent("study hard");
        articleDO.setTags("java");
        articleDO.setType(0);
        articleDO.setCategory("study");
        articleDO.setGmtCreate(0L);
        articleDO.setGmtUpdate(0L);
        articleDO.setTabloid("");
        articleDO.setComments(0);
        articleDO.setViews(0);
        articleRepository.save(articleDO);
        return "ok";
    }
    @GetMapping("/get")
    public List<ArticleDO> get() {
        return articleRepository.findAll();
    }
}
3. 在浏览器中测试
  • 先在浏览器输入http://localhost:8886/ins将数据插入数据库:
    插入数据
  • 然后输入http://localhost:8886/get从数据库中取出数据:
    获取数据
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值