博客地址:ONESTARの客栈
源码领取方式一:
- 扫一扫文末二维码,关注公众号【编程日刊】,后台回复【博客】,即可领取源码
源码领取方式二:
前端页面源码地址:github.com/oneStarLR/m…
以jpa为持久层源码地址:github.com/oneStarLR/m…
以mybatis为持久层源码地址:github.com/oneStarLR/m…
欢迎给star以鼓励(^_−)☆
本篇文章将从数据库的表结构来编写实体类,主要分析一下涉及到多表查询相关的实体类要如何设置变量(用户实体类在上篇文章中已经编写完)
在之前的文章中,都是先给出代码,然后做出分析,感觉这样不太好。咱们养成个习惯,先分析这代码要如何去写,再动手去写,不要一来就复制到你的IDEA,这样就少了思考的过程,还是要先分析一下,要有自己的理解,这样才有进步,授之以鱼不如授之以渔,思想才是最重要的!咱们要做一个有思想的,要根据需求提出问题,然后解决问题。
1.博客实体类
分析:
问:博客实体类需要设置哪些变量呢?
答:数据库中设计的属性:主键(id)、博客标题(title)、博客内容(content)、首图地址(firstPicture)、标记是否原创(flag)、浏览次数(views)、评论次数(commentCount)、是否开启赞赏(appreciation)、是否开启版权(shareStatement)、是否开启评论(commentabled)、是否发布(published)、是否推荐(recommend)、创建时间(createTime)、更新时间(updateTime)、博客描述(description)
问:这些属性就够了吗?还记不记得在之前设计表结构的时候,博客和分类是多对一的关系,博客和用户是多对一的关系,博客和评论是一对多的关系,在这些对应关系中,博客表和分类表、用户表、评论表都有关联,这里就要涉及到Mybatis的多对一和一对多的关系了,因此在实体类中也要体现出来,要如何体现呢?
答:除了上述变量外,还需要分类(type)、用户(user)、评论集合(comments)以及分类id(typeId)、用户id(userId),用来实现Mybatis的多表查询和相关功能。
在entity目录下创建Blog博客实体类,代码如下(省略get、set和toString方法):
package com.star.entity;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
/**
* @Description: 博客实体类
* @Date: Created in 10:10 2020/6/1
* @Author: ONESTAR
* @QQ群: 530311074
* @URL: https://onestar.newstar.net.cn/
*/
public class Blog {
private Long id;
private String title;
private String content;
private String firstPicture;
private String flag;
private Integer views;
private Integer commentCount;
private boolean appreciation;
private boolean shareStatement;
private boolean commentabled;
private boolean published;
private boolean recommend;
private Date createTime;
private Date updateTime;
private String description;
private Type type;
private User user;
private Long typeId;
private Long userId;
private List<Comment> comments = new ArrayList<>();
}
2.分类实体类
分析:
问:分类实体类需要设置哪些变量呢?
答:一个id和一个分类名称不就可以了吗。
问:可以吗?还记不记得在之前设计表结构的时候,博客和分类是多对一的关系,一篇博客对应一个分类,一个分类可以对应多篇博客,这里就要涉及到Mybatis的多对一和一对多的关系了,因此在实体类中也要体现出来,要如何体现呢?
答:除了id和分类名称外,还需要定义“博客”变量
在entity目录下创建Type分类实体类,代码如下(省略get、set和toString方法):
package com.star.entity;
import java.util.ArrayList;
import java.util.List;
/**
* @Description: 分类实体类
* @Date: Created in 17:26 2020/5/31
* @Author: ONESTAR
* @QQ群: 530311074
* @URL: https://onestar.newstar.net.cn/
*/
public class Type {
private Long id;
private String name;
private List<Blog> blogs = new ArrayList<>();
}
3.评论实体类
分析:
问:评论实体类需要设置哪些变量呢?
答:数据库中设计的属性:主键(id)、昵称(nickname)、邮箱(email)、头像(avatar)、评论内容(content)、创建时间(createTime)、博客id(blogId)、父评论id(parentCommentId)、是否为管理员评论(adminComment)
问:够了吗?同样,在之前表结构设计的时候,博客和评论是一对多的关系,评论和回复是一对多的关系,在实体类中当然也要体现出来,要如何体现呢?
答:除了上述变量外,还需要回复评论集合(replyComments)用来存储回复信息、父评论昵称(parentNickname)用来设置父级评论的id以及父评论(parentComment)用来显示父级评论姓名
在entity目录下创建Comment评论实体类,代码如下(省略get、set和toString方法):
package com.star.entity;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
/**
* @Description: 评论实体类
* @Date: Created in 11:12 2020/6/1
* @Author: ONESTAR
* @QQ群: 530311074
* @URL: https://onestar.newstar.net.cn/
*/
public class Comment {
private Long id;
private String nickname;
private String email;
private String content;
private String avatar;
private Date createTime;
private Long blogId;
private Long parentCommentId;
private boolean adminComment;
//回复评论
private List<Comment> replyComments = new ArrayList<>();
private Comment parentComment;
private String parentNickname;
}
4.留言实体类
留言和评论是一样的,只是少了博客id(blogId)变量,这里就不做分析,直接给出代码(省略get、set和toString方法):
package com.star.entity;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
/**
* @Description: 留言实体类
* @Date: Created in 11:44 2020/6/1
* @Author: ONESTAR
* @QQ群: 530311074
* @URL: https://onestar.newstar.net.cn/
*/
public class Message {
private Long id;
private String nickname;
private String email;
private String content;
private String avatar;
private Date createTime;
private Long parentMessageId;
private boolean adminMessage;
//回复留言
private List<Message> replyMessages = new ArrayList<>();
private Message parentMessage;
private String parentNickname;
}
5.友链实体类
友链没有和其他表进行关联,只有单表查询,变量就是属性,就不做分析,直接给代码(省略get、set和toString方法):
package com.star.entity;
import java.util.Date;
/**
* @Description: 友链实体类
* @Date: Created in 12:00 2020/6/1
* @Author: ONESTAR
* @QQ群: 530311074
* @URL: https://onestar.newstar.net.cn/
*/
public class FriendLink {
private Long id;
private String blogname;
private String blogaddress;
private String pictureaddress;
private Date createTime;
}
6.相册实体类
相册没有和其他表进行关联,只有单表查询,变量就是属性,就不做分析,直接给代码(省略get、set和toString方法):
package com.star.entity;
/**
* @Description: 相册实体类
* @Date: Created in 12:02 2020/6/1
* @Author: ONESTAR
* @QQ群: 530311074
* @URL: https://onestar.newstar.net.cn/
*/
public class Picture {
private Long id;
private String picturename;
private String picturetime;
private String pictureaddress;
private String picturedescription;
}
实体类构建完成,下一篇将讲述分类管理
【点关注,不迷路,欢迎持续关注本站】