package ${packageName}.service.impl; import ${packageName}.entity.${ClassName}; import ${packageName}.entity.dto.${ClassName}Dto; import ${packageName}.entity.vo.${ClassName}Vo; import ${packageName}.entity.query.${ClassName}Query; import ${packageName}.mapper.${ClassName}Mapper; import ${packageName}.service.${ClassName}Service; #if($table.hasOptionApi()) import cn.fateverse.common.core.entity.Option; #end import cn.fateverse.common.core.result.page.TableDataInfo; import cn.fateverse.common.mybatisplus.utils.PageUtils; import cn.fateverse.common.security.utils.SecurityUtils; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import lombok.extern.slf4j.Slf4j; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Propagation; import org.springframework.transaction.annotation.Transactional; import java.util.Arrays; import java.util.List; import java.util.stream.Collectors; /** * ${functionName} Controller * * @author ${author} * @date ${dateTime} */ @Slf4j @Service public class ${ClassName}ServiceImpl implements ${ClassName}Service { private final ${ClassName}Mapper ${className}Mapper; private final List columnNames = Arrays.asList(${table.getFieldList()}); public ${ClassName}ServiceImpl(${ClassName}Mapper ${className}Mapper) { this.${className}Mapper = ${className}Mapper; } @Override public ${ClassName}Vo searchById(${pkColumn.javaType} ${pkColumn.javaField}){ ${ClassName} ${className} = ${className}Mapper.selectById(${pkColumn.javaField}); return ${ClassName}Vo.to${ClassName}Vo(${className}); } @Override public TableDataInfo<${ClassName}Vo> searchList(${ClassName}Query query){ Page<${ClassName}> page = ${className}Mapper.selectPage(PageUtils.getPage(), buildQueryWrapper(query)); return PageUtils.convertDataTable(page, ${ClassName}Vo::to${ClassName}Vo); } #if($table.hasOptionApi()) @Override public List