若依代码生成器-Domain代码生成篇(一)

简介: 若依代码生成器-Domain代码生成篇(一)

若依代码生成器的前一段代码的阅读,我们了解了若依代码生成器的一些逻辑,包括通过数据库的information_schema. TABLES查询表信息,以及information_schema. COLUMNS查询指定表的列信息,将其转换到表gen_table与gen_table_column中的数据行,以便后续查询与代码转换。


今天我们继续来看若依系统中是如何自动生成domain代码的。


在系统菜单“系统工具”->"代码生成"中以及可以看到我们导入的表my_user,如下图所示:

这一行右侧有5个按钮,分别是预览、编辑、删除、同步、生成代码。


预览


我们点击“预览”,在弹出窗口中可以看到可以预览生成的代码包括:domain.java, mapper.java, service.java, serviceImpl.java,controller.java, mapper.xml, sql, api.js, index.vue。


其中domain.java, mapper.java, mapper.xml, sql都是与数据库紧密相关的,domain即生成对应数据库表的类,mapper与sql中则包含数据库基本的增删改查。


我们来研究一下domain的生成逻辑。


通过F12调试,发现点击预览的接口为:/tool/gen/preview/?id, 如下图所示:


接口代码经过查找,controller中如下:

/**
     * 预览代码
     */
    @PreAuthorize("@ss.hasPermi('tool:gen:preview')")
    @GetMapping("/preview/{tableId}")
    public AjaxResult preview(@PathVariable("tableId") Long tableId) throws IOException
    {
        Map<String, String> dataMap = genTableService.previewCode(tableId);
        return AjaxResult.success(dataMap);
    }

通过逐层分解,我们找到其中的一些关键代码:


mybatis的collections一对多查询


看过前两篇文章的小伙伴们知道,gen_table中的一行数据对应gen_table_column中的多行数据,那么mybatis是如何查询这种结果的呢?


这里有一个很好的示例。


其关键代码如下所图所示(源代码位于项目ruoyi-generator/resources/GenTableMapper.xml中)


具体的查询语句如下图所示:

目录
相关文章
|
JavaScript
若依代码生成自带导入功能
若依代码生成自带导入功能
565 0
|
SQL JSON 前端开发
|
2月前
|
数据库 开发者
EasyCode 自动生成代码
【10月更文挑战第16天】总的来说,EasyCode 自动生成代码是一款非常有价值的工具。它为开发者们带来了便捷、高效和创新,让软件开发变得更加轻松和有趣。随着技术的不断进步,相信 EasyCode 还会不断完善和发展,为开发者们提供更多更好的服务。
29 1
|
7月前
|
SQL 前端开发 JavaScript
基于若依框架实现前后端分离代码自动生成
基于若依框架实现前后端分离代码自动生成
1153 0
|
7月前
|
JavaScript 关系型数据库 Java
MyBatisPlus 最新版代码生成器(直接拿来就能用,包含自动生成 Vue 模版)
MyBatisPlus 最新版代码生成器(直接拿来就能用,包含自动生成 Vue 模版)
601 0
|
7月前
|
XML Java 数据库连接
代码生成插件easycode
代码生成插件easycode
|
7月前
|
SQL 资源调度 Java
mybatis-plus代码生成器的UI界面使用非常方便
mybatis-plus代码生成器的UI界面使用非常方便
125 0
Mybatis-plus-generator代码自动生成工具
Mybatis-plus-generator代码自动生成工具
98 0
|
7月前
如何使用MybatisPlus的代码生成器功能?
如何使用MybatisPlus的代码生成器功能?
|
存储 Java