Spring Boot中使用IntelliJ IDEA插件EasyCode一键生成代码详细方法


Posted in Python onMarch 20, 2020

今天为小伙伴们介绍一款 IntelliJ IDEA 上的免费开源插件,叫做 EasyCode,可以方便的根据数据库生成相应的代码。

EasyCode 是基于 IntelliJ IDEA 开发的代码生成插件,支持自定义任意模板(Java,html,js,xml);只要是与数据库相关的代码都可以通过自定义模板来生成;支持数据库类型与 java 类型映射关系配置;支持同时生成生成多张表的代码,张表有独立的配置信息,完全的个性化定义,规则由你设置。

我自己也稍微体验了一把,还是蛮方便的。

1.安装

首先点击 File->Settings->Plugins,然后搜索 EasyCode,如下:

Spring Boot中使用IntelliJ IDEA插件EasyCode一键生成代码详细方法

安装成功之后,重启 IDEA。

2.创建项目

接下来我给大家演示一个如何在 Spring Boot 中使用 EasyCode。首先我们在 IDEA 中创建一个 SpringBoot 项目,创建过程我就不多说了,如果大家不会,可以在我公众号后台回复 springboot,有详细的教程。

3.添加数据源

由于这个项目是基于 IDEA 上的 Database Tools 开发的,因此我们首先要通过 IDEA 上的 Database 连接数据源。

Spring Boot中使用IntelliJ IDEA插件EasyCode一键生成代码详细方法

接下来配置你的数据库连接信息,如果没有检测到合适的数据库 Driver,点击左下角自动下载:

Spring Boot中使用IntelliJ IDEA插件EasyCode一键生成代码详细方法

连接成功后,点击 OK。默认情况下没有展示连接下的数据库,需要我们手动勾选,例如我这里要连接 vhr 数据库,如下:

Spring Boot中使用IntelliJ IDEA插件EasyCode一键生成代码详细方法

4.生成代码

做完前面三步,准备工作就算 OK 了,接下来就是生成代码了。例如我想给 vhr 中所有的代码生成实体类、dao 层以及 service 层,方式如下:

首先选中所有的表,然后右键单击,选择 Easy Code->Generate Code,如下:

Spring Boot中使用IntelliJ IDEA插件EasyCode一键生成代码详细方法

第一次添加的时候,如果有数据库类型没有对应的 Java 类型,就会有提示,这个根据它的引导去添加映射关系即可,例如我在添加的时候,出了一个这个提示:

Spring Boot中使用IntelliJ IDEA插件EasyCode一键生成代码详细方法

点击 Yes,然后去添加自己的类型映射:

Spring Boot中使用IntelliJ IDEA插件EasyCode一键生成代码详细方法

添加成功之后,再去做代码生成,这下就可以了:

Spring Boot中使用IntelliJ IDEA插件EasyCode一键生成代码详细方法

这里,如果项目是多模块项目,可以先选择代码生成的 Module,然后设置代码生成的 package,最后从下面勾选要生成的代码模版,点击 OK 即可。

在代码生成的过程中,如果没检测到 package 下面有 service、dao 以及 entity 等包,工具会提示自动创建,点击 Yes 即可。

最终生成的代码如下:

Spring Boot中使用IntelliJ IDEA插件EasyCode一键生成代码详细方法

至此,各层的代码基本都生成了。大部分小伙伴用到这一步可能就 OK 了。

当然如果你觉得 EasyCode 自动生成的模版不够用,或者不好用,我们也可以自定义模版。

5.自定义模版

例如,我想在生成的 dao 层代码中,额外添加一个不需要任何条件,获取所有数据的方法(默认的生成模版中没有这个方法)。

点击 File->Settings->Easy Code->Template Setting:

Spring Boot中使用IntelliJ IDEA插件EasyCode一键生成代码详细方法

可以参考工具自己的定义方式,我们现在先在dao.java 中,添加如下方法:

/**
 * 查询所有数据
 *
 * @param $!tool.firstLowerCase($!{tableInfo.name}) 实例对象
 * @return 对象列表
 */
List<$!{tableInfo.name}> getAll();

然后再给它添加一个配套的 mapper.xml 中的方法,打开 mapper.xml ,添加如下方法:

<select id="getAll" resultMap="$!{tableInfo.name}Map">
  select
   #allSqlColumn()
  from $!{tableInfo.obj.parent.name}.$!tableInfo.obj.name
</select>

配置完成后,点击 OK。

接下来再去重新生成代码,就可以看到生成的方法中多了一个方法了,其他代码模版的定义与这个类似,就不再赘述了。

本文主地讲解了Spring Boot中使用IntelliJ IDEA插件EasyCode一键生成代码详细方法,更多关于IntelliJ IDEA插件使用技巧请查看下面的相关链接

Python 相关文章推荐
Python格式化css文件的方法
Mar 10 Python
介绍Python的Django框架中的QuerySets
Apr 20 Python
Python中如何获取类属性的列表
Dec 26 Python
详解python中字典的循环遍历的两种方式
Feb 07 Python
python验证码识别实例代码
Feb 03 Python
Python装饰器用法实例总结
May 26 Python
Python 查找list中的某个元素的所有的下标方法
Jun 27 Python
python os.path模块常用方法实例详解
Sep 16 Python
Face++ API实现手势识别系统设计
Nov 21 Python
详解Pandas之容易让人混淆的行选择和列选择
Jul 10 Python
nginx+uwsgi+django环境搭建的方法步骤
Nov 25 Python
Python判断三段线能否构成三角形的代码
Apr 12 Python
python+opencv实现移动侦测(帧差法)
Mar 20 #Python
Java Spring项目国际化(i18n)详细方法与实例
Mar 20 #Python
Python 自由定制表格的实现示例
Mar 20 #Python
python实现opencv+scoket网络实时图传
Mar 20 #Python
python实现同一局域网下传输图片
Mar 20 #Python
python实现udp传输图片功能
Mar 20 #Python
python实现UDP协议下的文件传输
Mar 20 #Python
You might like
详解PHP用substr函数截取字符串中的某部分
2016/12/03 PHP
thinkPHP多表查询及分页功能实现方法示例
2017/07/03 PHP
Laravel 5.5 的自定义验证对象/类示例代码详解
2017/08/29 PHP
推荐一些非常不错的javascript学习资源站点
2007/08/29 Javascript
用js实现的页面关键字密度查询代码
2007/12/27 Javascript
jquery的live使用注意事项
2014/02/18 Javascript
js自动生成的元素与页面原有元素发生堆叠的解决方法
2014/09/04 Javascript
jquery UI Datepicker时间控件的使用方法(终结版)
2015/11/07 Javascript
Node.js数据库操作之查询MySQL数据库(二)
2017/03/04 Javascript
详解vuejs几种不同组件(页面)间传值的方式
2017/06/01 Javascript
JS实现移动端触屏拖拽功能
2018/07/31 Javascript
Vue组件教程之Toast(Vue.extend 方式)详解
2019/01/27 Javascript
javascript实现图片轮播代码
2019/07/09 Javascript
JS将时间秒转换成天小时分钟秒的字符串
2019/07/10 Javascript
vue中npm包全局安装和局部安装过程
2019/09/03 Javascript
高性能web服务器框架Tornado简单实现restful接口及开发实例
2014/07/16 Python
Python中的True,False条件判断实例分析
2015/01/12 Python
python使用os.listdir和os.walk获得文件的路径的方法
2017/12/16 Python
TensorFlow损失函数专题详解
2018/04/26 Python
numpy数组之存取文件的实现示例
2019/05/24 Python
python Dijkstra算法实现最短路径问题的方法
2019/09/19 Python
python调用百度API实现人脸识别
2020/11/17 Python
python中entry用法讲解
2020/12/04 Python
美国男装连锁零售商:Men’s Wearhouse
2016/10/14 全球购物
英国婴儿和儿童服装网站:Vertbaudet
2018/04/02 全球购物
Deichmann英国:德国鞋类零售商
2021/01/30 全球购物
华为智利官方商店:Huawei Chile
2020/05/09 全球购物
2014新课程改革心得体会
2014/03/10 职场文书
《高尔基和他的儿子》教学反思
2014/04/09 职场文书
2014年小学辅导员工作总结
2014/12/23 职场文书
个人廉洁自律总结
2015/03/06 职场文书
网站文案策划岗位职责
2015/04/14 职场文书
CSS3鼠标悬浮过渡缩放效果
2021/04/17 HTML / CSS
Node.js实现断点续传
2021/06/23 Javascript
使用Spring处理x-www-form-urlencoded方式
2021/11/02 Java/Android
box-shadow单边阴影的实现
2023/05/21 HTML / CSS