SpringCloud微服务实战——搭建企业级开发框架(三十二):代码生成器使用配置说明

简介: 一、新建数据源配置  因考虑到多数据源问题,代码生成器作为一个通用的模块,后续可能会为其他工程生成代码,所以,这里不直接读取系统工程配置的数据源,而是让用户自己维护。

一、新建数据源配置


  因考虑到多数据源问题,代码生成器作为一个通用的模块,后续可能会为其他工程生成代码,所以,这里不直接读取系统工程配置的数据源,而是让用户自己维护。


微信图片_20220519132359.png


新建数据源


参数说明


  • 数据源名称:用于查找区分数据源的名称



  • 用户名:登录数据库的用户名


  • 密码:登录数据库的密码


  • 数据库驱动:数据库驱动类型,例:com.mysql.jdbc.Driver(MySQL5 )或 com.mysql.cj.jdbc.Driver(MySQL8 )


  • 数据库类型:选择对应的数据库类型,如果有新增可以新增数据字典


  • 备注:备注信息


二、新建业务数据字典


  界面的增删改查界面会有一些数据字典的下拉框或者单选、多选等基础数据,这些根据具体需要生成代码的表设计提前做好规划,在业务字典中提前建好数据字典。在自定类型表,点击一条记录所在的行即是选中,右侧字典值列表会出现对应的字典值列表。


微信图片_20220519132402.png


业务字典


三、代码生成的基础配置


  代码生成的基础配置实际也是一类数据字典,但这是只针对代码生成功能模块使用的数据字典,比如在界面上选择的数据库类型、表单展现类型、树类型等、都是获取这里的配置数据。在实际应用开发过程中,可以根据自己的需求进行新增、修改。


微信图片_20220519132405.png


基础配置


四、校验规则配置


  在我们业务开发过程中,无论是界面还是接口,都会对数据字段的长度、大小、类型等进行校验,这里的配置主要是配置数据字段校验的正则表达式,在代码生成时,会在前端代码和后台代码添加校验方法进行数据校验。



微信图片_20220519132409.png


正则表达式校验规则


五、代码配置(重点)


  代码配置是实际代码生成的重点,以上几项配置都是为代码生成做前期准备工作,代码配置模块是实际的针对业务表进行配置,最终生成代码。


1、 新建代码配置


微信图片_20220519132413.png


新增代码配置


配置参数说明


  • 数据源  :选择我们上面配置的需要生成代码的数据库。


  • 模块名称:需要生成代码的模块名称,这个名称将用作菜单名称、系统提示等。


  • 模块代码:系统在生成代码时会根据模块代码新建对应名称的目录,进行存放该模块的代码。


  • 服务名称:微服务注册到Nacos上的名称,框架中这个取得的是微服务pom.xml里的artifactId配置,在生成代码时,微服务名称将加在请求url的前面,请一定确认这个字段的正确性,否则访问不到后台服务。


  • 表名    : 需要生成代码的表。


  • 表别名  :在生成多表联合代码时,这个作为表的别名在查询语句的mapper文件中使用。


  • 表前缀  :在我们定义表时,t_代码是表(table的首字母),下划线后面代码子系统的名称,再后面是模块名称,那么在我们生成代码时,前面的前缀需要去掉,只保留模块名称,即生成代码时的实体类名称。


  • 父级包名:定义生成模块代码的包路径,代码将存放在这个包名下。


  • 表单类型:在进行增删查改时的展现方式,有弹出框、新打开一个页面、右侧伸缩抽屉等形式


  • 表单列数:定义表单字段在表里每行展示几列


  • 数据展示:配置数据查询列表的展示形式,有表格、树等形式


  • 左树类型: 当数据展示形式包含左侧树时,这里可以选择左侧树的数据类型


  • Controller请求路径:配置在Controller代码中的 @RequestMapping 参数,即模块的请求路径


  • 后端代码保存路径:后端代码的存放路径,到具体微服务的根目录即可,即src目录的上一级目录,不需要具体到src目录和src下面的目录。


  • 前端代码保存路径:前端代码的存放路径,到具体前端代码的根目录即可。


  • 页面文件目录自定义: 前端代码默认放到views目录下,不设置的话会使用服务请求和模块代码两级字段开始生成目录,如果需要大的区分,这里可以再设置一级目录。


  • 生成类型:有些代码生成可能只有接口,或者只想重新生成页面代码,那么这里可以选择是全部生成,还是只生成后端代码或前端代码。


  • 状态处理:具体业务模块中,状态是一个常用的字段,如果要生成的代码有状态字段,那么这里可以选择是否生成对状态相关操作代码。


  • 支持导出:配置该模块是否有导出功能。


  • 支持导入:配置该模块是否有导入功能。


  • 联表类型:配置该模块在操作时,是进行多表操作还是单表操作。


  • 查询复用:代码中列表查询(分页或不分页)和单条记录查询可以使用同一条sql,基于性能方面考虑,这里可以选择是生成单独的查询方法,还是复用同一个查询方法。


2、配置代码生成规则


  在已建好的代码配置列表中点击"配置规则"按钮,进入到代码生成规则配置页面。如果在上一步中选择的是多表查询,那么这里会进入多表配置界面,如果选择的是单表,那么这里直接进入字段配置界面。


  1. 配置联表


  • 多表配置列表


微信图片_20220519132416.png


多表配置列表


  • 多表配置表单


微信图片_20220519132420.png


多表配置表单


配置参数说明


  • 表名             : 选择相同数据源下的表。


  • 别名             : 联表查询时,mapper.xml里面SQL语句的表别名。


  • 表前缀          : 去除系统和模块标识,只保留实体名称。


  • 排序              :   显示排序及在SQL查询时的排序。


  • 联表方式       :   表连接方式,LEFT JOIN、RIGHT JOIN、INNER JOIN、UNION、UNION ALL等


  • 查询字段       : 此表需要查询的字段


  • 自定义on条件:   需要和主表关联的字段及自定义的条件


  1. 配置字段


微信图片_20220519132423.png


字段配置


配置参数说明


  • 字段描述             : 获取数据表的描述信息,用于字段名称和展示在页面字段的label。


  • 字段类型             : 自动转换数据库定义的字段类型为JAVA对应的字段类型。


  • 字段名称             : 实体类里面字段的定义。


  1. 配置表单


微信图片_20220519132427.png


表单配置


配置参数说明


  • 表单新增             : 字段是否展示在界面的新增表单。


  • 表单编辑             : 字段是否展示在界面的编辑表单。


  • 组件类型             : 字段展示在界面的类型,INPUT、SELECT、CHECKBOX等。


  • 字典编码             : 当字段的组件类型为选择类型时,提供选择的填充数据。此数据来自业务字典。


  1. 配置表单校验


微信图片_20220519132431.png

表单校验


配置参数说明


  • 最小长度             : 字段的最小长度,初始值来自数据库字段定义。


  • 最大长度             : 字段的最大长度,初始值来自数据库字段定义。


  • 是否必填             : 字段是否必填。


  • 是否唯一             : 字段是否唯一,如果配置为唯一,那么在表单新增或编辑时会自动生成校验方法。


  • 校验类型             : 选择已配置的通用正则表达式。


  • 正则表达式         : 对于非通用的特殊字段,可以自定义正则表达式。


  • 最大值                : 当字段为数值类型时,字段的最大值,初始值来自数据库字段定义。


  • 最小值                : 当字段为数值类型时, 字段的最小值,初始值来自数据库字段定义。


  1. 配置数据展示列表


微信图片_20220519132435.png


列表配置


配置参数说明


  • 查询条件             : 是否是查询条件,展示在界面的查询条件区域。


  • 查询类型             : 字段的查询类型,等于、不等于、大于、小于等。


  • 列表展示             : 是否展示在查询结果的数据表格中。


  • 支持导入             :   字段是否支持导入,在代码配置中支持导入时,此字段生效。


  • 支持导出             :   字段是否支持导出,在代码配置中支持导出时,此字段生效。


  1. 完成保存配置,在列表中点击生成代码按钮,生成代码。


微信图片_20220519132438.png


执行生成代码操作


六、配置资源权限


  执行完代码生成操作之后,会在后台代码的mapper.xml同级目录生成一个同名的.sql文件,这里面是访问新生成代码模块的资源菜单权限脚本。

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
8月前
|
算法 Java 微服务
【SpringCloud(1)】初识微服务架构:创建一个简单的微服务;java与Spring与微服务;初入RestTemplate
微服务架构是What?? 微服务架构是一种架构模式,它提出将单一应用程序划分为一组小的服务,服务之间互相协调、互相配合,为用户提供最终价值。 每个服务允许在其独立的进程中,服务于服务间采用轻量级的通信机制互相协作(通常是Http协议的RESTful API或RPC协议)。 每个服务都围绕着具体业务进行构建,并且能够被独立的部署到生产环境、类生产环境等。另外应当尽量避免统一的、集中式的服务管理机制,对具体的一个服务而言,应根据上下文,选择合适的语言、工具对其进行构建
692 126
|
8月前
|
负载均衡 算法 Java
【SpringCloud(2)】微服务注册中心:Eureka、Zookeeper;CAP分析;服务注册与服务发现;单机/集群部署Eureka;连接注册中心
1. 什么是服务治理? SpringCloud封装了Netfix开发的Eureka模块来实现服务治理 在传统pc的远程调用框架中,管理每个服务与服务之间依赖关系比较复杂,管理比较复杂,所以需要使用服务治理,管理服务于服务之间依赖关系,可以实现服务调用、负载均衡、容错等,实现服务发现与注册
455 0
|
8月前
|
负载均衡 Java API
《深入理解Spring》Spring Cloud 构建分布式系统的微服务全家桶
Spring Cloud为微服务架构提供一站式解决方案,涵盖服务注册、配置管理、负载均衡、熔断限流等核心功能,助力开发者构建高可用、易扩展的分布式系统,并持续向云原生演进。
|
设计模式 Java API
微服务架构演变与架构设计深度解析
【11月更文挑战第14天】在当今的IT行业中,微服务架构已经成为构建大型、复杂系统的重要范式。本文将从微服务架构的背景、业务场景、功能点、底层原理、实战、设计模式等多个方面进行深度解析,并结合京东电商的案例,探讨微服务架构在实际应用中的实施与效果。
898 6
|
设计模式 Java API
微服务架构演变与架构设计深度解析
【11月更文挑战第14天】在当今的IT行业中,微服务架构已经成为构建大型、复杂系统的重要范式。本文将从微服务架构的背景、业务场景、功能点、底层原理、实战、设计模式等多个方面进行深度解析,并结合京东电商的案例,探讨微服务架构在实际应用中的实施与效果。
471 1
|
安全 应用服务中间件 API
微服务分布式系统架构之zookeeper与dubbo-2
微服务分布式系统架构之zookeeper与dubbo-2
|
负载均衡 Java 应用服务中间件
微服务分布式系统架构之zookeeper与dubbor-1
微服务分布式系统架构之zookeeper与dubbor-1
|
Java 开发者 微服务
从单体到微服务:如何借助 Spring Cloud 实现架构转型
**Spring Cloud** 是一套基于 Spring 框架的**微服务架构解决方案**,它提供了一系列的工具和组件,帮助开发者快速构建分布式系统,尤其是微服务架构。
2670 70
从单体到微服务:如何借助 Spring Cloud 实现架构转型
|
运维 监控 持续交付
微服务架构解析:跨越传统架构的技术革命
微服务架构(Microservices Architecture)是一种软件架构风格,它将一个大型的单体应用拆分为多个小而独立的服务,每个服务都可以独立开发、部署和扩展。
3812 37
微服务架构解析:跨越传统架构的技术革命
|
人工智能 安全 Java
微服务引擎 MSE:打造通用的企业级微服务架构
微服务引擎MSE致力于打造通用的企业级微服务架构,涵盖四大核心内容:微服务技术趋势与挑战、MSE应对方案、拥抱开源及最佳实践。MSE通过流量入口、内部流量管理、服务治理等模块,提供高可用、跨语言支持和性能优化。此外,MSE坚持开放,推动云原生与AI融合,助力企业实现无缝迁移和高效运维。
794 1