Java通过数据库表生成实体类详细过程
作者:你家宝宝 发布时间:2024-01-23 15:39:06
项目背景
最近在做的项目,涉及到数据库的操作了,之前做的是直接调用接口,不用做存库操作。
因此要增加大量特殊格式的实体类。比如我们用的是 JPA ,要增加一些注解,额外还有 lombok 的一些注解。
所以,这个项目的目的是,根据数据库中的某张表,生成与之对应的实体类。使用的技术是Freemarker 模板引擎,自定义了实体的模板。
最终的目标是,生成实体类的内容即可。有需要的朋友,可以改改,直接生成java文件。我这里觉得 使用 swagger 生成代码,放到最终的响应里,也是很不错的。
使用的是 Java 11 版本,用到的技术有 lombok,swagger,springboot,spring-data,freemarker,druid。
项目代码
项目代码托管在以下位置。各位可以直接 pull 下来,运行。需要注意的是,改数据库连接。
https://gitee.com/fengsoshuai/generate-entity-from-table
使用说明
配置相关
在 application.yml 文件中配置好自己的数据库。
随后启动 GenerateEntityFromTableApplication 类。
控制台会输出:
Application 'GenerateEntity' is running! Access URLs:
Local: http://localhost:80
External: http://192.168.1.2:80
Doc: http://192.168.1.2:80/doc.html
访问最后一行 Doc 对应的连接地址。会进入 swagger 的测试界面。
swagger操作
输入参数后,点击发送按钮,在响应结果中会带出你想要的结果,比如:
package org.feng.entity;
import lombok.Data;
import org.springframework.data.relational.core.mapping.Column;
import org.springframework.data.relational.core.mapping.Table;
/**
* 宝宝写的一实体类
*
* @version v2.0
*/
@Data
@Table("student")
public class StudentData {
@Column("id")
private Integer id;
@Column("name")
private String name;
@Column("age")
private Integer age;
@Column("weight")
private Double weight;
@Column("height")
private Double height;
@Column("modified")
private LocalDateTime modified;
}
目前的缺点
目前的缺点是,没有对LocalDateTime
等特殊类型做兼容,需要手动导入包。
以上的实体类,是从数据库表中查 student 表,生成的。
我的数据表结构是:
SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;
-- ----------------------------
-- Table structure for student
-- ----------------------------
DROP TABLE IF EXISTS `student`;
CREATE TABLE `student` (
`id` int(0) NOT NULL AUTO_INCREMENT,
`name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
`age` int(0) NULL DEFAULT NULL,
`weight` double NULL DEFAULT NULL,
`height` double NULL DEFAULT NULL,
`modified` timestamp(0) NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0),
PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 11 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
SET FOREIGN_KEY_CHECKS = 1;
来源:https://fengjinsong.blog.csdn.net/article/details/125958359


猜你喜欢
- 最终的效果废话不多少,直接上图这里可以清楚的看到,数据库里包含了日期,内容,和网站link下面我们来分析怎么实现使用的库import req
- 引擎简介Innodb引擎Innodb引擎提供了对数据库ACID事务的支持,并且实现了SQL标准的四种隔离级别。该引擎还提供了行级锁和外键约束
- 本文实例讲述了Laravel框架实现定时发布任务的方法。分享给大家供大家参考,具体如下:背景:需要每隔一小时新建一个任务http://lar
- 下文分步骤给大家介绍的非常详细,具体详情请看下文吧。一、准备用两台服务器做测试:Master Server: 192.0.0.1/Linux
- 在本教程中使用MySQL最新的MySQL服务8.0.11的社区绿色版本进行安装,绿色版为zip格式的包,安装分为以下四步走:第一步:下载My
- win8下python安装和环境配置,具体内容如下python语法较C语言简单,容易上手。具体步骤 1.本文采用的是win8.1 64位系统
- 随着互联网的快速发展和数据交换的广泛应用,各种数据格式的处理成为软件开发中的关键问题。JSON 作为一种通用的数据交换格式,在各种应用场景中
- 在python自动化中,经常会遇到对数据文件的操作,比如添加多名员工,但是直接将员工数据写在python文件中,不但工作量大,要是以后再次遇
- 在ASP输出页面只是调出数据库里内容展现给用户看没有使用SESSION等动态属性,是可以CACHE的,以加快访问速度具体操作方法如下:在as
- 步骤创建 vue 的脚手架npm install -g @vue/clivue init webpack绑定 git 项目cd existi
- 1. MySQL慢查询介绍 MySQL的慢查询日志是MySQL提供的一种日志记录,它用来记录在MySQL中响应时间超
- 最近跟着OpenCV2-Python-Tutorials在学习python_opencv中直方图的反向投影时,第一种方法是使用numpy实现
- 之前一直没弄清jsonArray和jsonObject的区别,今天终于弄明白了。jsonArray是数组,以[ ]包含数据,jsonObje
- 01、文件操作文件是操作系统提供给用户/应用程序操作硬盘的一个虚拟的概念/接口用户/应用程序可以通过文件将数据永久保存在硬盘中用户/应用程序
- MySQL设置当前时间为默认值的问题我们经常会遇到,下面就为您介绍MySQL设置当前时间为默认值的实现全步骤,希望对您能有所启迪。数据库:t
- 本文介绍了SpringBoot开启数据库迁移的FlyWay使用,分享给大家,具体如下:一,首先我先了解下FlyWay是如何运转的。最简单的方
- 第一种: php部分 <?php if($_FILES['file']['error']&
- 缘由最近在做公司的一个点餐H5项目需要前端动态计算用户选的商品的总价(单价*数量)和购物车的总价格时发现关于 JavaScript 浮点数计
- 一朋友委托我帮他投票,地址在: http://publish.sina.com.cn/04/13/413/search.php 投票的链接是
- Python下有许多款不同的 Web 框架。Django是重量级选手中最有代表性的一位。许多成功的网站和APP都基于Django。Djang