news 2026/4/18 12:40:37

【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/18 3:31:29

39、深入了解Solaris文件系统框架

深入了解Solaris文件系统框架 1. Solaris文件系统框架概述 Solaris引入了虚拟文件系统框架,在此框架下可实现多种文件系统类型。早期的Unix实现通常为所有挂载的文件系统使用单一的文件系统类型,比如BSD Unix的UFS文件系统。虚拟文件系统框架的开发是为了让Sun的分布式计算…

作者头像 李华
网站建设 2026/4/17 21:36:10

【学习心得】基于FunASR推理的SenseVoiceSmall模型来实现语音识别

一、介绍一下SenseVoiceSmall 1、什么是SenseVoiceSmall SenseVoice是多语言音频理解模型,支持语音识别、语种识别、语音情感识别、声学事件检测、逆文本正则化等能力,采用工业级数十万小时的标注音频进行模型训练,保证了模型的通用识别效果…

作者头像 李华
网站建设 2026/4/18 3:29:30

20、CUPS与LPRng打印服务器配置详解

CUPS与LPRng打印服务器配置详解 1. CUPS配置 CUPS(通用Unix打印系统)的配置文件位于 /etc/cups 目录下,这些文件的具体信息见下表: | 文件名 | 描述 | | — | — | | classes.conf | 不同打印机类别的配置 | | client.conf | 指定客户端的特定选项列表 | | cupsd.…

作者头像 李华
网站建设 2026/4/18 3:26:44

14、Kubernetes 集群管理、扩展与网络基础

Kubernetes 集群管理、扩展与网络基础 1. 自定义资源(CRD) 自定义资源(Custom Resources)自 Kubernetes 1.7 版本引入,旨在让用户创建自定义 API 对象,使其表现得如同原生 Kubernetes 对象,从而扩展 Kubernetes 以支持特定应用或用例。创建自定义资源有两种方式:使用…

作者头像 李华
网站建设 2026/4/18 3:26:42

22、Kubernetes资源管理、伸缩与持续交付指南

Kubernetes资源管理、伸缩与持续交付指南 1. 资源请求与限制 在Kubernetes中,我们可以为命名空间指定默认的资源请求和限制。若在创建Pod时未指定请求和限制,将使用默认设置。这可通过 LimitRange 对象实现,它包含 defaultRequest (请求)和 default (限制)字段。…

作者头像 李华
网站建设 2026/4/18 3:27:18

终极硬件信息获取解决方案:hwinfo跨平台库全面解析

终极硬件信息获取解决方案:hwinfo跨平台库全面解析 【免费下载链接】hwinfo cross platform C library for hardware information (CPU, RAM, GPU, ...) 项目地址: https://gitcode.com/gh_mirrors/hw/hwinfo hwinfo是一款功能强大的跨平台C硬件信息获取库&a…

作者头像 李华