欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MybatisPlus代碼生成器使用示例

 更新時間:2024年06月12日 10:00:01   作者:康提扭狗兔  
MyBatis-Plus自動化的生成與數(shù)據(jù)庫表對應(yīng)的Java代碼文件,本文主要介紹了MybatisPlus代碼生成器使用示例,具有一定的參考價值,感興趣的可以了解一下

前言 

MyBatis-Plus 的代碼生成器主要是基于 MyBatis-Plus 的元數(shù)據(jù)分析功能,通過讀取數(shù)據(jù)庫中的表結(jié)構(gòu)信息,生成對應(yīng)的 Entity、Mapper、Service、Controller 等代碼文件。

元數(shù)據(jù)分析: 代碼生成器首先連接到數(shù)據(jù)庫,讀取數(shù)據(jù)庫中的表結(jié)構(gòu)信息,包括表名、字段名、字段類型、注釋等元數(shù)據(jù)信息。

模板引擎: 代碼生成器使用模板引擎來生成代碼文件。模板文件定義了生成文件的結(jié)構(gòu)和內(nèi)容,其中可以包含一些占位符,用于動態(tài)替換成實際的數(shù)據(jù),如表名、字段名等。

代碼生成: 根據(jù)元數(shù)據(jù)信息和模板文件,代碼生成器生成對應(yīng)的 Java 代碼文件。生成的文件包括 Entity 類(對應(yīng)數(shù)據(jù)庫表的字段)、Mapper 接口(提供數(shù)據(jù)庫操作方法)、Service 類(封裝業(yè)務(wù)邏輯)、Controller 類(處理 HTTP 請求)等。

自定義配置: 代碼生成器提供了豐富的配置選項,可以根據(jù)用戶的需求進行靈活配置。用戶可以指定生成的包名、輸出路徑、命名規(guī)則等,以滿足不同項目的需求。

執(zhí)行生成: 用戶運行代碼生成器的程序,代碼生成器根據(jù)配置信息讀取數(shù)據(jù)庫表結(jié)構(gòu),并根據(jù)模板文件生成對應(yīng)的代碼文件,最終輸出到指定的路徑中。

總的來說,MyBatis-Plus 的代碼生成器利用數(shù)據(jù)庫的元數(shù)據(jù)信息和模板文件,自動化地生成與數(shù)據(jù)庫表對應(yīng)的 Java 代碼文件,極大地提高了開發(fā)效率,減少了重復(fù)勞動。

針對數(shù)據(jù)庫中的實體類表,自動生成相關(guān)的pojo類,mapper,service等

1. Get-Started

基于mybatisplus,idea下載mybatisplus插件

在這里插入圖片描述

sql文件

/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET NAMES utf8 */;
/*!50503 SET NAMES utf8mb4 */;
/*!40103 SET @OLD_TIME_ZONE=@@TIME_ZONE */;
/*!40103 SET TIME_ZONE='+00:00' */;
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;
/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;

DROP TABLE IF EXISTS `learning_lesson`;
CREATE TABLE IF NOT EXISTS `learning_lesson` (
  `id` bigint NOT NULL COMMENT '主鍵',
  `user_id` bigint NOT NULL COMMENT '學(xué)員id',
  `course_id` bigint NOT NULL COMMENT '課程id',
  `status` tinyint DEFAULT '0' COMMENT '課程狀態(tài),0-未學(xué)習,1-學(xué)習中,2-已學(xué)完,3-已失效',
  `week_freq` tinyint DEFAULT NULL COMMENT '每周學(xué)習頻率,例如每周學(xué)習6小節(jié),則頻率為6',
  `plan_status` tinyint NOT NULL DEFAULT '0' COMMENT '學(xué)習計劃狀態(tài),0-沒有計劃,1-計劃進行中',
  `learned_sections` int NOT NULL DEFAULT '0' COMMENT '已學(xué)習小節(jié)數(shù)量',
  `latest_section_id` bigint DEFAULT NULL COMMENT '最近一次學(xué)習的小節(jié)id',
  `latest_learn_time` datetime DEFAULT NULL COMMENT '最近一次學(xué)習的時間',
  `create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '創(chuàng)建時間',
  `expire_time` datetime DEFAULT NULL COMMENT '過期時間',
  `update_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新時間',
  PRIMARY KEY (`id`) USING BTREE,
  UNIQUE KEY `idx_user_id` (`user_id`,`course_id`) USING BTREE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci ROW_FORMAT=DYNAMIC COMMENT='學(xué)生課程表';

-- 正在導(dǎo)出表  tj_learning.learning_lesson 的數(shù)據(jù):~4 rows (大約)
DELETE FROM `learning_lesson`;
INSERT INTO `learning_lesson` (`id`, `user_id`, `course_id`, `status`, `week_freq`, `plan_status`, `learned_sections`, `latest_section_id`, `latest_learn_time`, `create_time`, `expire_time`, `update_time`) VALUES
	(1, 2, 2, 2, 6, 1, 12, 16, '2023-04-11 22:34:45', '2022-08-05 20:02:50', '2023-08-05 20:02:29', '2023-04-19 10:29:29'),
	(2, 2, 3, 1, 4, 1, 3, 31, '2023-04-19 11:42:50', '2022-08-06 15:16:48', '2023-08-06 15:16:37', '2023-04-19 11:42:50'),
	(1585170299127607297, 129, 2, 0, NULL, 0, 0, 16, '2023-04-11 22:37:05', '2022-12-05 23:00:29', '2023-10-26 15:14:54', '2023-04-11 22:37:05'),
	(1601061367207464961, 2, 1549025085494521857, 1, 3, 1, 4, 1550383240983875589, '2023-04-11 16:34:44', '2022-12-09 11:49:11', '2023-12-09 11:49:11', '2023-04-11 16:34:43');

/*!40103 SET TIME_ZONE=IFNULL(@OLD_TIME_ZONE, 'system') */;
/*!40101 SET SQL_MODE=IFNULL(@OLD_SQL_MODE, '') */;
/*!40014 SET FOREIGN_KEY_CHECKS=IFNULL(@OLD_FOREIGN_KEY_CHECKS, 1) */;
/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
/*!40111 SET SQL_NOTES=IFNULL(@OLD_SQL_NOTES, 1) */;

代碼生成前的目錄結(jié)構(gòu)

在這里插入圖片描述

2. 代碼生成步驟

2.1 連接數(shù)據(jù)庫

在這里插入圖片描述

2.2 配置代碼生成器

在這里插入圖片描述

在這里插入圖片描述

點擊 code generator

2.3 生成的代碼

在這里插入圖片描述

替換id生成方式,改為雪花算法

在這里插入圖片描述

2.4 單元測試

在這里插入圖片描述

在這里插入圖片描述

到此這篇關(guān)于MybatisPlus代碼生成器使用示例的文章就介紹到這了,更多相關(guān)MybatisPlus 代碼生成器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家! 

相關(guān)文章

最新評論