mirror of
				https://github.com/yangzongzhuan/RuoYi-Vue.git
				synced 2025-10-26 20:32:04 +00:00 
			
		
		
		
	代码生成模板支持主子表
This commit is contained in:
		| @@ -18,7 +18,7 @@ import com.ruoyi.common.enums.BusinessType; | ||||
| import ${packageName}.domain.${ClassName}; | ||||
| import ${packageName}.service.I${ClassName}Service; | ||||
| import com.ruoyi.common.utils.poi.ExcelUtil; | ||||
| #if($table.crud) | ||||
| #if($table.crud || $table.sub) | ||||
| import com.ruoyi.common.core.page.TableDataInfo; | ||||
| #elseif($table.tree) | ||||
| #end | ||||
| @@ -41,7 +41,7 @@ public class ${ClassName}Controller extends BaseController | ||||
|      */ | ||||
|     @PreAuthorize("@ss.hasPermi('${permissionPrefix}:list')") | ||||
|     @GetMapping("/list") | ||||
| #if($table.crud) | ||||
| #if($table.crud || $table.sub) | ||||
|     public TableDataInfo list(${ClassName} ${className}) | ||||
|     { | ||||
|         startPage(); | ||||
|   | ||||
| @@ -6,7 +6,7 @@ import ${import}; | ||||
| import org.apache.commons.lang3.builder.ToStringBuilder; | ||||
| import org.apache.commons.lang3.builder.ToStringStyle; | ||||
| import com.ruoyi.common.annotation.Excel; | ||||
| #if($table.crud) | ||||
| #if($table.crud || $table.sub) | ||||
| import com.ruoyi.common.core.domain.BaseEntity; | ||||
| #elseif($table.tree) | ||||
| import com.ruoyi.common.core.domain.TreeEntity; | ||||
| @@ -18,7 +18,7 @@ import com.ruoyi.common.core.domain.TreeEntity; | ||||
|  * @author ${author} | ||||
|  * @date ${datetime} | ||||
|  */ | ||||
| #if($table.crud) | ||||
| #if($table.crud || $table.sub) | ||||
| #set($Entity="BaseEntity") | ||||
| #elseif($table.tree) | ||||
| #set($Entity="TreeEntity") | ||||
| @@ -49,6 +49,11 @@ public class ${ClassName} extends ${Entity} | ||||
|     private $column.javaType $column.javaField; | ||||
|  | ||||
| #end | ||||
| #end | ||||
| #if($table.sub) | ||||
|     /** $table.subTable.functionName信息 */ | ||||
|     private List<${subClassName}> ${subclassName}List; | ||||
|  | ||||
| #end | ||||
| #foreach ($column in $columns) | ||||
| #if(!$table.isSuperColumn($column.javaField)) | ||||
| @@ -69,6 +74,18 @@ public class ${ClassName} extends ${Entity} | ||||
| #end | ||||
| #end | ||||
|  | ||||
| #if($table.sub) | ||||
|     public List<${subClassName}> get${subClassName}List() | ||||
|     { | ||||
|         return ${subclassName}List; | ||||
|     } | ||||
|  | ||||
|     public void set${subClassName}List(List<${subClassName}> ${subclassName}List) | ||||
|     { | ||||
|         this.${subclassName}List = ${subclassName}List; | ||||
|     } | ||||
|  | ||||
| #end | ||||
|     @Override | ||||
|     public String toString() { | ||||
|         return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) | ||||
| @@ -79,6 +96,9 @@ public class ${ClassName} extends ${Entity} | ||||
| #set($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) | ||||
| #end | ||||
|             .append("${column.javaField}", get${AttrName}()) | ||||
| #end | ||||
| #if($table.sub) | ||||
|             .append("${subclassName}List", get${subClassName}List()) | ||||
| #end | ||||
|             .toString(); | ||||
|     } | ||||
|   | ||||
| @@ -2,6 +2,9 @@ package ${packageName}.mapper; | ||||
|  | ||||
| import java.util.List; | ||||
| import ${packageName}.domain.${ClassName}; | ||||
| #if($table.sub) | ||||
| import ${packageName}.domain.${subClassName}; | ||||
| #end | ||||
|  | ||||
| /** | ||||
|  * ${functionName}Mapper接口 | ||||
| @@ -58,4 +61,31 @@ public interface ${ClassName}Mapper | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int delete${ClassName}ByIds(${pkColumn.javaType}[] ${pkColumn.javaField}s); | ||||
| #if($table.sub) | ||||
|  | ||||
|     /** | ||||
|      * 批量删除${subTable.functionName} | ||||
|      *  | ||||
|      * @param customerIds 需要删除的数据ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int delete${subClassName}By${subTableFkClassName}s(${pkColumn.javaType}[] ${pkColumn.javaField}s); | ||||
|      | ||||
|     /** | ||||
|      * 批量新增${subTable.functionName} | ||||
|      *  | ||||
|      * @param ${subclassName}List ${subTable.functionName}列表 | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int batch${subClassName}(List<${subClassName}> ${subclassName}List); | ||||
|      | ||||
|  | ||||
|     /** | ||||
|      * 通过${functionName}ID删除${subTable.functionName}信息 | ||||
|      *  | ||||
|      * @param roleId 角色ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
|     public int delete${subClassName}By${subTableFkClassName}(${pkColumn.javaType} ${pkColumn.javaField}); | ||||
| #end | ||||
| } | ||||
|   | ||||
| @@ -9,6 +9,12 @@ import com.ruoyi.common.utils.DateUtils; | ||||
| #end | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.stereotype.Service; | ||||
| #if($table.sub) | ||||
| import java.util.ArrayList; | ||||
| import com.ruoyi.common.utils.StringUtils; | ||||
| import org.springframework.transaction.annotation.Transactional; | ||||
| import ${packageName}.domain.${subClassName}; | ||||
| #end | ||||
| import ${packageName}.mapper.${ClassName}Mapper; | ||||
| import ${packageName}.domain.${ClassName}; | ||||
| import ${packageName}.service.I${ClassName}Service; | ||||
| @@ -55,6 +61,9 @@ public class ${ClassName}ServiceImpl implements I${ClassName}Service | ||||
|      * @param ${className} ${functionName} | ||||
|      * @return 结果 | ||||
|      */ | ||||
| #if($table.sub) | ||||
|     @Transactional | ||||
| #end | ||||
|     @Override | ||||
|     public int insert${ClassName}(${ClassName} ${className}) | ||||
|     { | ||||
| @@ -63,7 +72,13 @@ public class ${ClassName}ServiceImpl implements I${ClassName}Service | ||||
|         ${className}.setCreateTime(DateUtils.getNowDate()); | ||||
| #end | ||||
| #end | ||||
| #if($table.sub) | ||||
|         int rows = ${className}Mapper.insert${ClassName}(${className}); | ||||
|         insert${subClassName}(${className}); | ||||
|         return rows; | ||||
| #else | ||||
|         return ${className}Mapper.insert${ClassName}(${className}); | ||||
| #end | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -72,6 +87,9 @@ public class ${ClassName}ServiceImpl implements I${ClassName}Service | ||||
|      * @param ${className} ${functionName} | ||||
|      * @return 结果 | ||||
|      */ | ||||
| #if($table.sub) | ||||
|     @Transactional | ||||
| #end | ||||
|     @Override | ||||
|     public int update${ClassName}(${ClassName} ${className}) | ||||
|     { | ||||
| @@ -79,6 +97,10 @@ public class ${ClassName}ServiceImpl implements I${ClassName}Service | ||||
| #if($column.javaField == 'updateTime') | ||||
|         ${className}.setUpdateTime(DateUtils.getNowDate()); | ||||
| #end | ||||
| #end | ||||
| #if($table.sub) | ||||
|         ${className}Mapper.delete${subClassName}By${subTableFkClassName}(${className}.get${pkColumn.capJavaField}()); | ||||
|         insert${subClassName}(${className}); | ||||
| #end | ||||
|         return ${className}Mapper.update${ClassName}(${className}); | ||||
|     } | ||||
| @@ -89,9 +111,15 @@ public class ${ClassName}ServiceImpl implements I${ClassName}Service | ||||
|      * @param ${pkColumn.javaField}s 需要删除的${functionName}ID | ||||
|      * @return 结果 | ||||
|      */ | ||||
| #if($table.sub) | ||||
|     @Transactional | ||||
| #end | ||||
|     @Override | ||||
|     public int delete${ClassName}ByIds(${pkColumn.javaType}[] ${pkColumn.javaField}s) | ||||
|     { | ||||
| #if($table.sub) | ||||
|         ${className}Mapper.delete${subClassName}By${subTableFkClassName}s(${pkColumn.javaField}s); | ||||
| #end | ||||
|         return ${className}Mapper.delete${ClassName}ByIds(${pkColumn.javaField}s); | ||||
|     } | ||||
|  | ||||
| @@ -104,6 +132,35 @@ public class ${ClassName}ServiceImpl implements I${ClassName}Service | ||||
|     @Override | ||||
|     public int delete${ClassName}ById(${pkColumn.javaType} ${pkColumn.javaField}) | ||||
|     { | ||||
| #if($table.sub) | ||||
|         ${className}Mapper.delete${subClassName}By${subTableFkClassName}(${pkColumn.javaField}); | ||||
| #end | ||||
|         return ${className}Mapper.delete${ClassName}ById(${pkColumn.javaField}); | ||||
|     } | ||||
| #if($table.sub) | ||||
|  | ||||
|     /** | ||||
|      * 新增${subTable.functionName}信息 | ||||
|      *  | ||||
|      * @param ${className} ${functionName}对象 | ||||
|      */ | ||||
|     public void insert${subClassName}(${ClassName} ${className}) | ||||
|     { | ||||
|         List<${subClassName}> ${subclassName}List = ${className}.get${subClassName}List(); | ||||
|         Long ${pkColumn.javaField} = ${className}.get${pkColumn.capJavaField}(); | ||||
|         if (StringUtils.isNotNull(${subclassName}List)) | ||||
|         { | ||||
|             List<${subClassName}> list = new ArrayList<${subClassName}>(); | ||||
|             for (${subClassName} ${subclassName} : ${subclassName}List) | ||||
|             { | ||||
|                 ${subclassName}.set${subTableFkClassName}(${pkColumn.javaField}); | ||||
|                 list.add(${subclassName}); | ||||
|             } | ||||
|             if (list.size() > 0) | ||||
|             { | ||||
|                 ${className}Mapper.batch${subClassName}(list); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| #end | ||||
| } | ||||
|   | ||||
| @@ -0,0 +1,76 @@ | ||||
| package ${packageName}.domain; | ||||
|  | ||||
| #foreach ($import in $subImportList) | ||||
| import ${import}; | ||||
| #end | ||||
| import org.apache.commons.lang3.builder.ToStringBuilder; | ||||
| import org.apache.commons.lang3.builder.ToStringStyle; | ||||
| import com.ruoyi.common.annotation.Excel; | ||||
| import com.ruoyi.common.core.domain.BaseEntity; | ||||
|  | ||||
| /** | ||||
|  * ${subTable.functionName}对象 ${subTableName} | ||||
|  *  | ||||
|  * @author ${author} | ||||
|  * @date ${datetime} | ||||
|  */ | ||||
| public class ${subClassName} extends BaseEntity | ||||
| { | ||||
|     private static final long serialVersionUID = 1L; | ||||
|  | ||||
| #foreach ($column in $subTable.columns) | ||||
| #if(!$table.isSuperColumn($column.javaField)) | ||||
|     /** $column.columnComment */ | ||||
| #if($column.list) | ||||
| #set($parentheseIndex=$column.columnComment.indexOf("(")) | ||||
| #if($parentheseIndex != -1) | ||||
| #set($comment=$column.columnComment.substring(0, $parentheseIndex)) | ||||
| #else | ||||
| #set($comment=$column.columnComment) | ||||
| #end | ||||
| #if($parentheseIndex != -1) | ||||
|     @Excel(name = "${comment}", readConverterExp = "$column.readConverterExp()") | ||||
| #elseif($column.javaType == 'Date') | ||||
|     @JsonFormat(pattern = "yyyy-MM-dd") | ||||
|     @Excel(name = "${comment}", width = 30, dateFormat = "yyyy-MM-dd") | ||||
| #else | ||||
|     @Excel(name = "${comment}") | ||||
| #end | ||||
| #end | ||||
|     private $column.javaType $column.javaField; | ||||
|  | ||||
| #end | ||||
| #end | ||||
| #foreach ($column in $subTable.columns) | ||||
| #if(!$table.isSuperColumn($column.javaField)) | ||||
| #if($column.javaField.length() > 2 && $column.javaField.substring(1,2).matches("[A-Z]")) | ||||
| #set($AttrName=$column.javaField) | ||||
| #else | ||||
| #set($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) | ||||
| #end | ||||
|     public void set${AttrName}($column.javaType $column.javaField)  | ||||
|     { | ||||
|         this.$column.javaField = $column.javaField; | ||||
|     } | ||||
|  | ||||
|     public $column.javaType get${AttrName}()  | ||||
|     { | ||||
|         return $column.javaField; | ||||
|     } | ||||
| #end | ||||
| #end | ||||
|  | ||||
|     @Override | ||||
|     public String toString() { | ||||
|         return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) | ||||
| #foreach ($column in $subTable.columns) | ||||
| #if($column.javaField.length() > 2 && $column.javaField.substring(1,2).matches("[A-Z]")) | ||||
| #set($AttrName=$column.javaField) | ||||
| #else | ||||
| #set($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)}) | ||||
| #end | ||||
|             .append("${column.javaField}", get${AttrName}()) | ||||
| #end | ||||
|             .toString(); | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user
	 RuoYi
					RuoYi