news 2026/2/5 6:55:57

【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/2/5 4:20:10

19、Linux内核模块安装与打印服务器配置全解析

Linux内核模块安装与打印服务器配置全解析 1. 内核新模块安装 Linux内核源代码包含大量模块,但系统实际使用的只是其中一部分。安装新设备时,可能需要安装为其提供驱动的内核模块。具体步骤如下: 1. 确保内核源代码安装 :要保证内核源代码已安装在 /usr/src/linux 目…

作者头像 李华
网站建设 2026/2/5 6:08:53

18、Kubernetes 监控与日志管理:从基础到实战

Kubernetes 监控与日志管理:从基础到实战 1. Prometheus 监控配置 在某些情况下,我们可能希望获取服务下单个 Pod 的指标,而非整个服务所有 Pod 的指标。由于大多数端点对象并非手动创建,端点发现模式会使用从服务继承的注解。这就导致当我们为服务添加注解时,该注解会同…

作者头像 李华
网站建设 2026/2/3 8:11:31

KH Coder终极指南:免费开源文本分析工具快速上手

KH Coder终极指南:免费开源文本分析工具快速上手 【免费下载链接】khcoder KH Coder: for Quantitative Content Analysis or Text Mining 项目地址: https://gitcode.com/gh_mirrors/kh/khcoder 想要从海量文本中挖掘深层洞察却苦于编程门槛?&am…

作者头像 李华
网站建设 2026/2/3 11:36:08

7、Linux桌面环境全解析:选择与使用指南

Linux桌面环境全解析:选择与使用指南 1. 常见Linux桌面环境介绍 1.1 Unity桌面环境 Unity是Ubuntu的默认桌面环境,基于GNOME 3开发,外观和操作上与GNOME 3非常相似。不过,它刚推出时存在一些小问题,这也引起了Linux社区部分人的不满,因为Ubuntu背后的Canonical公司没有…

作者头像 李华
网站建设 2026/2/3 4:15:15

MCA Selector:Minecraft世界区块管理的终极解决方案

MCA Selector:Minecraft世界区块管理的终极解决方案 【免费下载链接】mcaselector Querz/mcaselector: 是一个用于 Minecraft 的多玩家选择器,可以用于 Minecraft 服务器中快速选择多个玩家,支持多种 Minecraft 服务器和版本。 项目地址: h…

作者头像 李华
网站建设 2026/2/4 4:44:42

5个必学的动态图标状态管理技巧:让你的界面活起来

5个必学的动态图标状态管理技巧:让你的界面活起来 【免费下载链接】lucide Beautiful & consistent icon toolkit made by the community. Open-source project and a fork of Feather Icons. 项目地址: https://gitcode.com/GitHub_Trending/lu/lucide …

作者头像 李华