洞悉MySQL底层架构,【一键生成代码,阿里开发7年大牛

#if($column.attrType == ‘LocalDateTime’)

import java.time.LocalDateTime;

#break

#end

#end

import lombok.Data;

/**

  • Description: ${comments}

  • Create Date: ${date}

  • @author ${author}

  • @version ${version}

*/

@Data

@ApiModel(value = “ c l a s s N a m e D T O " , d e s c r i p t i o n = " 数据传输对象 {className}DTO", description = "数据传输对象 classNameDTO",description="数据传输对象{className}DTO”)

public class ${className}DTO extends BaseDTO {

#foreach ($column in $columns)

/**

  • $column.comments

*/

@ApiModelProperty(notes = “$column.comments”)

#if($column.attrname == ‘id’ || $column.attrname.indexOf(‘Id’) != -1)

@JsonFormat(shape = JsonFormat.Shape.STRING)

#end

#if (“date” == $column.dataType)

@JsonFormat(shape = JsonFormat.Shape.STRING, pattern = “yyyy-MM-dd”)

#end

#if (“datetime” == $column.dataType)

@JsonFormat(shape = JsonFormat.Shape.STRING, pattern = “yyyy-MM-dd HH:mm:ss”)

#end

private $column.attrType $column.attrname;

#end

}

复制代码

2.4 功能分析


下面简单分析下我的这套代码生成器的功能,从代码接口层面看主要有两个:

  • 生成规则

简单来说就是生成代码时指定的一些内容,比如作者,包路径,是否去除表前缀等等。

这是一套完成的增删改查功能,前端可以直接接入。

实体类如下:

/**

  • Module: GenerateRulesDO.java

  • @author weirx

  • @since JDK 1.8

  • @version 1.0

  • @date 2020-07-17T10:00:32.925

  • @Descriptions:

*/

@Data

@TableName(value = “bssp_generate_rules”)

public class GenerateRulesDO {

/**

  • 主键

*/

@TableId(value = “id”, type = IdType.AUTO)

private Long id;

/**

  • 作者

*/

private String author;

/**

  • 包名

*/

private String packageName;

/**

  • 服务名

*/

private String serviceName;

/**

  • 是否忽略前缀 1是0否

*/

private Integer isIgnorePrefix;

/**

  • 表前缀

*/

private String tablePrefix;

/**

  • 创建时间

*/

@TableField(fill = FieldFill.INSERT)

@JSONField(format = “yyyy-MM-dd HH:mm:ss”)

private LocalDateTime createTime;

/**

  • 更新时间

*/

@TableField(fill = FieldFill.INSERT_UPDATE)

@JSONField(format = “yyyy-MM-dd HH:mm:ss”)

private LocalDateTime updateTime;

}

复制代码

  • 生成代码

生成代码的主要过程如下所示:

此三种都有对应的接口实现。

2.5 代码逻辑分析


关于代码逻辑分析,我已生成本地zip为例,简单讲解主要的逻辑。

  • 定义本地代码生成位置

#代码生成路径

generator:

code:

path: rob-necessities-generator/src/main/resources/generate/code.zip

复制代码

引用:

@Value(“${generator.code.path}”)

private String generatorCodePath;

复制代码

  • 生成接口入口位置

/**

  • 代码生成-返回zip

  • @param tableDTO

  • @return

*/

@ApiOperation(value = “代码生成-生成zip到项目”)

@PostMapping(“/generateCodeZip”)

public void generateCodeZip(@RequestBody TableDTO tableDTO) {

try {

ByteArrayOutputStream outputStream = generateService.generateCode(TableDoConvert.dtoToDo(tableDTO));

FileOutputStream fos = new FileOutputStream(generatorCodePath);

outputStream.writeTo(fos);

fos.close();

outputStream.close();

} catch (IOException e) {

e.printStackTrace();

}

}

复制代码

此处的参数是TableDTO当中的表名数组,支持多个同时生成:

/**

  • 表名称数组

*/

@ApiModelProperty(notes = “创建时间”)

private String[] tableNames;

复制代码

  • 生成代码接口实现

@Override

public ByteArrayOutputStream generateCode(TableDO tableDO) throws IOException {

// 获取生成规则

List list = generateRulesService.list();

if (CollectionUtils.isEmpty(list)) {

return null;

}

ByteArrayOutputStream outputStream = new ByteArrayOutputStream();

ZipOutputStream zip = new ZipOutputStream(outputStream);

// 遍历表名

for (String tableName : tableDO.getTableNames()) {

// 根据表名查询,获取表的结构

TableDO table = generateMapper.queryTable(tableName);

// 获取表字段

List columns = generateMapper.queryColumns(tableName);

// 生成逻辑

this.generatorCode(table, list.get(0), columns, zip);

}

// 关闭流

IOUtils.closeQuietly(zip);

return outputStream;

}

复制代码

主要分为以下几个步骤:

  • 获取生成规则

  • 根据表名查询,获取表的结构

实际是通过如下的sql查询:

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
img

总结

三套“算法宝典”

28天读完349页,这份阿里面试通关手册,助我闯进字节跳动

算法刷题LeetCode中文版(为例)

人与人存在很大的不同,我们都拥有各自的目标,在一线城市漂泊的我偶尔也会羡慕在老家踏踏实实开开心心养老的人,但是我深刻知道自己想要的是一年比一年有进步。

最后,我想说的是,无论你现在什么年龄,位于什么城市,拥有什么背景或学历,跟你比较的人永远都是你自己,所以明年的你看看与今年的你是否有差距,不想做咸鱼的人,只能用尽全力去跳跃。祝愿,明年的你会更好!

由于篇幅有限,下篇的面试技术攻克篇只能够展示出部分的面试题,详细完整版以及答案解析,有需要的可以关注

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
img

etCode中文版(为例)

人与人存在很大的不同,我们都拥有各自的目标,在一线城市漂泊的我偶尔也会羡慕在老家踏踏实实开开心心养老的人,但是我深刻知道自己想要的是一年比一年有进步。

最后,我想说的是,无论你现在什么年龄,位于什么城市,拥有什么背景或学历,跟你比较的人永远都是你自己,所以明年的你看看与今年的你是否有差距,不想做咸鱼的人,只能用尽全力去跳跃。祝愿,明年的你会更好!

由于篇幅有限,下篇的面试技术攻克篇只能够展示出部分的面试题,详细完整版以及答案解析,有需要的可以关注

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
[外链图片转存中…(img-Oo4kwAI7-1712548960064)]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值