This is the 9th day of my participation in the November Gwen Challenge. Check out the event details: The last Gwen Challenge 2021

Two days ago, through the article: Reading the previous section of code generator in Code Generator in Code Generator in Code Generator in Code Generator in Code Generator in Code Generator in Code Generator in Code Generator in code Generator in code Generator in code Generator in code Generator in code Generator in code generator in code generator in code generator in code generator And information_schema. COLUMNS queries the column information of the specified table and converts it to the data rows in the tables GEN_TABLE and gen_table_column for subsequent queries and code conversions.

Today we will continue to look at how domain code is automatically generated in a dependency system.

In the system menu “System Tools” ->” Code Generation “and you can see our imported table my_user, as shown below:

There are five buttons on the right of this line: Preview, Edit, Delete, Synchronize, and Generate code.

preview

We click “preview” and in the popup window you can see that the code generated by preview includes: Java, servicePl. Java, Controller. Java, mapper. XML, SQL, api.js, index.vue.

Java, mapper. Java, mapper. XML and SQL are all closely related to the database. Domain is the class that generates the corresponding database table, and Mapper and SQL contain the basic increase, deletion, change and search of the database.

Let’s look at the domain generation logic.

F12: /tool/gen/preview/? Id, as shown in the figure below:

The interface code is found as follows in controller:

/** * Preview code */
    @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);
    }
Copy the code

By breaking it down layer by layer, we found some key code:

Mybatis collections one-to-many query

Mybatis (gen_table_column, gen_table_column, gen_table_column)

Here’s a good example.

The key code shown in the following figure (ruoyi source is located in the project – the generator/resources/GenTableMapper. XML)

The specific query statement is shown in the figure below:

In this way, we mapped the one-to-many data query from the database to GenTable, an object in Java, to facilitate subsequent code generation.