news 2026/4/23 12:59:21

【JavaWeb】日程管理03——准备数据库和实体类

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【JavaWeb】日程管理03——准备数据库和实体类

目录

  • 准备数据库
  • 准备实体类
    • lombok使用步骤
      • 1 检查idea是否已经安装了lombok插件
      • 2 检查是否勾选了 enable annotation processing
      • 3 导入lombok的依赖
      • 4 在实体类上添加注解

准备数据库

创建数据库

新建查询

SET NAMES utf8;SET FOREIGN_KEY_CHECKS=0;DROP TABLE IF EXISTS `sys_schedule`;CREATE TABLE `sys_schedule`(`sid` int NOT NULL AUTO_INCREMENT,`uid` int NULL DEFAULT NULL,`title`varchar(20),`completed`int(1)NULL DEFAULT NULL,PRIMARY KEY(`sid`)USING BTREE)ENGINE=InnoDB AUTO_INCREMENT=1;DROP TABLE IF EXISTS `sys_user`;CREATE TABLE `sys_user`(`uid` int NOT NULL AUTO_INCREMENT,`username`varchar(10),`user_pwd`varchar(100),PRIMARY KEY(`uid`)USING BTREE,UNIQUE INDEX `username`(`username`)USING BTREE)ENGINE=InnoDB;INSERT INTO `sys_user` VALUES(1,'zhangsan','e10adc3949ba59abbe56e057f20f883e');INSERT INTO `sys_user` VALUES(2,'lisi','e10adc3949ba59abbe56e057f20f883e');SET FOREIGN_KEY_CHECKS=1;

准备实体类

创建模块

添加tomcat依赖

增加web资源组件

创建实体类

起类名的时候注意一下驼峰转换
对于数据库中表名用下划线分隔,Java中会转成驼峰式,比如这里数据库中表名为sys_user,转换成SysUser

和数据库对应的实体类一般有如下要求

  1. 实体类的类名和表格名称应该对应(对应不是一致)
  2. 实体类的属性名和表格的列名应该对应
  3. 每个属性都必须是私有的
  4. 每个属性都应该具备getter setter
  5. 必须具备无参构造器
    不写默认会有,但是如果写了其他有参构造器,无参构造器就没了,所以无参需要写出
  6. 应该实现序列化接口(缓存 分布式项目数据传递 可能会将对象序列化)
  7. 应该重写类的hashcode和equals方法
  8. toString是否重写都可以

一路Next

完整代码

package com.baidu.scheduler.pojo;import java.util.Objects;public classSysUserimplementsSerializable{private Integer uid;private String username;private String userPwd;publicSysUser(Integer uid,String username,String userPwd){this.uid=uid;this.username=username;this.userPwd=userPwd;}publicSysUser(){}public IntegergetUid(){returnuid;}public voidsetUid(Integer uid){this.uid=uid;}public StringgetUsername(){returnusername;}public voidsetUsername(String username){this.username=username;}public StringgetUserPwd(){returnuserPwd;}public voidsetUserPwd(String userPwd){this.userPwd=userPwd;}public booleanequals(Object o){if(this==o)returntrue;if(o==null||getClass()!=o.getClass())returnfalse;SysUser sysUser=(SysUser)o;returnObjects.equals(uid,sysUser.uid)&&Objects.equals(username,sysUser.username)&&Objects.equals(userPwd,sysUser.userPwd);}public inthashCode(){returnObjects.hash(uid,username,userPwd);}public StringtoString(){return"SysUser{"+"uid="+uid+", username='"+username+'\''+", userPwd='"+userPwd+'\''+'}';}}

使用lombok帮助我们生成这些内容(getter setter 全参构造 无参构造 equals hashcode)

lombok使用步骤

1 检查idea是否已经安装了lombok插件

2 检查是否勾选了 enable annotation processing

注意:这个勾选未必是永久有效的,使用前记得检查

3 导入lombok的依赖

4 在实体类上添加注解

添加AllArgsConstructor之后相当于添加了全参构造

@NoArgsConstructor//添加了无参构造@Getter @Setter @ToString @EqualsAndHashCode @Data 等同于下面四个的合并 @Getter @Setter @ToString @EqualsAndHashCode

创建另一个实体类

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/21 9:14:43

10、Linux 软件管理:.bash_profile、CVS 与 RPM 全方位指南

Linux 软件管理:.bash_profile、CVS 与 RPM 全方位指南 1. .bash_profile 配置路径变量 在 Linux 系统中,用户可以通过在 .bashrc 或 .bash_profile 文件中进行 PATH 赋值来定制自己的 PATH 变量。这样,用户就能在自己的用户目录中访问自己创建或安装的命令和程序…

作者头像 李华
网站建设 2026/4/23 9:54:07

OFD.js终极指南:3步实现浏览器OFD文档完美渲染

OFD.js是一款纯前端OFD文件处理工具,专门解决浏览器中OFD文档的解析和渲染需求。作为OFD文档在线预览的利器,它采用SVG和Canvas技术实现100%前端渲染,无需后端支持即可在网页中直接展示OFD文件内容。 【免费下载链接】ofd.js 项目地址: ht…

作者头像 李华
网站建设 2026/4/23 11:17:04

21、Kubernetes资源管理与伸缩:全面指南

Kubernetes资源管理与伸缩:全面指南 1. 优先级与资源抢占 在Kubernetes环境中,当添加高优先级的Pod时,低优先级的Pod可能会被终止。例如,执行以下命令查看Pod状态: $ kubectl get pod -o wide NAME READY STATUS RESTARTS AGE IP NODE NOMINATED…

作者头像 李华
网站建设 2026/4/23 12:34:35

27、在 AWS 上搭建和管理 Kubernetes 集群

在 AWS 上搭建和管理 Kubernetes 集群 1. ELB 介绍与使用 AWS 提供了名为经典负载均衡器(Classic Load Balancer)的强大软件负载均衡器,它曾被称为弹性负载均衡器(Elastic Load Balancer,ELB)。ELB 可以将网络流量负载均衡到一个或多个 EC2 实例,还能卸载 SSL/TLS 加密…

作者头像 李华
网站建设 2026/4/23 11:37:38

32、在 Azure 上部署和管理 Kubernetes 集群

在 Azure 上部署和管理 Kubernetes 集群 1. 从零构建集群 如果你想自行构建 Kubernetes 集群,可以参考 AKS - engine 项目(https://github.com/Azure/aks - engine),它使用 Azure 资源管理器在 Azure 中构建 Kubernetes 基础设施。 2. 在 AKS 上设置第一个 Kubernetes 集…

作者头像 李华
网站建设 2026/4/23 11:17:08

解锁光学材料数据宝库:从入门到实战的完整指南

解锁光学材料数据宝库:从入门到实战的完整指南 【免费下载链接】refractiveindex.info-database Database of optical constants 项目地址: https://gitcode.com/gh_mirrors/re/refractiveindex.info-database 你是否曾在设计光学系统时,为找不到…

作者头像 李华