使用idea插件进行java代码生成的操作

java代码生成

使用idea的插件codehelper.generator进行代码生成,可以根据entity,生成对应的

1、建表sql语句

2、dao.java文件

3、dao.xml文件

4、service.java文件

同时这个插件还能在new了entity之后生成所有的set方法

多次生成,不会影响自己手动添加的代码

安装

安装插件codehelper.generator

案例

@Data
@AllArgsConstructor
@NoArgsConstructor
public class UserEntity {
  @Id
  private Integer id;

  private String name;

  /**
   * 1启用,0停用
   */
  private Integer state;

  private String remark;
  @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
  @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
  private Date addtime;
  @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
  @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
  private Date stoptime;
}

生成set

UserEntity user=new UserEntity();

//new了之后在下一行:点击tool--codeHelper--GenAllSetter

生成代码

点击tool--codeHelper--tox Boxes--在弹窗中输入entity,多个使用'|'分隔,就会在当前文件夹生成代码

sql

-- auto Generated on 2020-01-14 12:49:57
-- DROP TABLE IF EXISTS `user_entity`;
CREATE TABLE user_entity(
  `id` INTEGER(20) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT 'id',
  `name` VARCHAR(50) NOT NULL DEFAULT '' COMMENT 'name',
  `state` INTEGER(12) NOT NULL DEFAULT -1 COMMENT '1启用,0停用',
  `remark` VARCHAR(50) NOT NULL DEFAULT '' COMMENT 'remark',
  `addtime` DATETIME NOT NULL DEFAULT '1000-01-01 00:00:00' COMMENT 'addtime',
  `stoptime` DATETIME NOT NULL DEFAULT '1000-01-01 00:00:00' COMMENT 'stoptime',
  PRIMARY KEY (`id`)
)ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT 'user_entity';

dao

package com.demo1.invoice.entity.user;
import org.apache.ibatis.annotations.Param;
import java.util.List;
import com.demo1.invoice.entity.user.UserEntity;

public interface UserEntityDao {

  int insert(@Param("pojo") UserEntity pojo);
  int insertList(@Param("pojos") List< UserEntity> pojo);
  List<UserEntity> select(@Param("pojo") UserEntity pojo);
  int update(@Param("pojo") UserEntity pojo);
}

xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="com.demo1.invoice.entity.user.UserEntityDao">

<!--auto generated Code-->
  <resultMap id="AllColumnMap" type="com.demo1.invoice.entity.user.UserEntity">
    <result column="id" property="id"/>
    <result column="name" property="name"/>
    <result column="state" property="state"/>
    <result column="remark" property="remark"/>
    <result column="addtime" property="addtime"/>
    <result column="stoptime" property="stoptime"/>
  </resultMap>

<!--auto generated Code-->
  <sql id="all_column">
    id,
    name,
    state,
    remark,
    addtime,
    stoptime
  </sql>

<!--auto generated Code-->
  <insert id="insert">
    INSERT INTO user_entity
    <trim prefix="(" suffix=")" suffixOverrides=",">
      <if test="pojo.id != null"> id, </if>
      <if test="pojo.name != null"> name, </if>
      <if test="pojo.state != null"> state, </if>
      <if test="pojo.remark != null"> remark, </if>
      <if test="pojo.addtime != null"> addtime, </if>
      <if test="pojo.stoptime != null"> stoptime, </if>
    </trim>
    VALUES
    <trim prefix="(" suffix=")" suffixOverrides=",">
      <if test="pojo.id != null"> #{pojo.id}, </if>
      <if test="pojo.name != null"> #{pojo.name}, </if>
      <if test="pojo.state != null"> #{pojo.state}, </if>
      <if test="pojo.remark != null"> #{pojo.remark}, </if>
      <if test="pojo.addtime != null"> #{pojo.addtime}, </if>
      <if test="pojo.stoptime != null"> #{pojo.stoptime}, </if>
    </trim>
  </insert>

<!--auto generated Code-->
  <insert id="insertList">
    INSERT INTO user_entity(
    <include refid="all_column"/>
    )VALUES
    <foreach collection="pojos" item="pojo" index="index" separator=",">
      (
      #{pojo.id},
      #{pojo.name},
      #{pojo.state},
      #{pojo.remark},
      #{pojo.addtime},
      #{pojo.stoptime}
      )
    </foreach>
  </insert>

<!--auto generated Code-->
  <update id="update">
    UPDATE user_entity
    <set>
      <if test="pojo.id != null"> id = #{pojo.id}, </if>
      <if test="pojo.name != null"> name = #{pojo.name}, </if>
      <if test="pojo.state != null"> state = #{pojo.state}, </if>
      <if test="pojo.remark != null"> remark = #{pojo.remark}, </if>
      <if test="pojo.addtime != null"> addtime = #{pojo.addtime}, </if>
      <if test="pojo.stoptime != null"> stoptime = #{pojo.stoptime} </if>
    </set>
     WHERE id = #{pojo.id}
  </update>

<!--auto generated Code-->
  <select id="select" resultMap="AllColumnMap">
    SELECT <include refid="all_column"/>
    FROM user_entity
    <where>
      <if test="pojo.id != null"> AND id = #{pojo.id} </if>
      <if test="pojo.name != null"> AND name = #{pojo.name} </if>
      <if test="pojo.state != null"> AND state = #{pojo.state} </if>
      <if test="pojo.remark != null"> AND remark = #{pojo.remark} </if>
      <if test="pojo.addtime != null"> AND addtime = #{pojo.addtime} </if>
      <if test="pojo.stoptime != null"> AND stoptime = #{pojo.stoptime} </if>
    </where>
    LIMIT 1000
  </select>

<!--auto generated Code-->
  <delete id="delete">
    DELETE FROM user_entity where id = #{id}
  </delete>
</mapper>

service

import org.springframework.stereotype.Service;
import javax.annotation.Resource;
import java.util.List;
import com.demo1.invoice.entity.user.UserEntity;
import com.demo1.invoice.entity.user.UserEntityDao;

@Service
public class UserEntityService {

  @Resource
  private UserEntityDao userEntityDao;

  public int insert(UserEntity pojo){
    return userEntityDao.insert(pojo);
  }

  public int insertList(List< UserEntity> pojos){
    return userEntityDao.insertList(pojos);
  }

  public List<UserEntity> select(UserEntity pojo){
    return userEntityDao.select(pojo);
  }

  public int update(UserEntity pojo){
    return userEntityDao.update(pojo);
  }

}

补充知识:IDEA 新建junit单元测试

1. 新建test目录

在src同级目录下新建test文件夹,右键test文件夹设置为Test Source Root

2. 创建测试类

选中要创建单元测试的实现类,并将焦点放在编辑器中(鼠标在编辑器中点击一下),菜单栏选择Navigate----Test(Mac快捷键:Cmd+shift+t):

选择创建新的测试:

选中要测试的方法,以及生成@Before:

这样之后就会在test下新建一个测试类:

3. 测试函数介绍

测试类中包含两个函数:

@Before

public void setUp() throws Exception

这个是测试方法执行前执行的函数,假如在测试方法中需要使用该类中的成员变量,那么可以在该函数中定义该成员变量。

@Test

public void findUserById() throws Exception

这个便是测试函数。点击编辑器左列的小工具即可发起测试。

以上这篇使用idea插件进行java代码生成的操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • IDEA自定义常用代码块及自定义快捷摸板

    前言 .如何设置 设置使用的地方 1.设置类注释模板代码 /** * @author: lujie * @create: $date$ * @description: $description$ **/ 2.JUC-lock锁代码块 lock.lock(); try { } catch (Exception e) { e.printStackTrace(); } finally { lock.unlock(); } PS:下面看下idea自定义快捷代码生成模板 idea中使用psvm 以及sou

  • IDEA2020.1个性化设置的实现

    一.个性化主题设置 第一步:获得主题文件,推荐主题下载网址 http://www.soft-hub.cn或http://www.riaway.com/ 第二步:在你喜欢的磁盘下随意新建一个文件夹用以存放主题文件,例如文件夹可取名为idea_theme 第三步:打开软件IDEA,依次点开File -> Manage IDE Settings -> Imort Settings,选择你的主题文件 第四步:根据提示依次选择ok然后restart,而后将自动重启软件,主题设置完成! 二.字体设置 代码

  • 将idea工程打包成jar文件的全步骤

    前言 近日在工作中遇到了一个问题,需要把本地的java文件打成jar包,传到云服务器上运行.于是学习了一下如何在intellijidea中将java工程打成jar包. 步骤如下: *File->PorjectStructure *在ProjectSetings中选择Artifects.点击+号选择jar文件中的Empty选项 *在Name选项中修改jar文件的名字.*然后点击下方的CreatManifest按钮,点击ok(应该默认是当前工程) * 点击Main Class右侧的文件夹图标,选择当

  • IDEA的基本使用(让你的IDEA有飞一般的感觉)

    1.设置maven 在File->settings->搜索maven Mavan home directory--设置maven安装包的bin文件夹所在的位置 User settings file--设置setting文件所在的位置 Local repository--设置本地仓库的 2.IDEA 设置代码行宽度 在File->settings->Editor->Code Style 有人会问,如果输入的代码超出宽度界线时,如何让IDE自动将代码换行?有两种方式! 第一种,在

  • 使用idea插件进行java代码生成的操作

    java代码生成 使用idea的插件codehelper.generator进行代码生成,可以根据entity,生成对应的 1.建表sql语句 2.dao.java文件 3.dao.xml文件 4.service.java文件 同时这个插件还能在new了entity之后生成所有的set方法 多次生成,不会影响自己手动添加的代码 安装 安装插件codehelper.generator 案例 @Data @AllArgsConstructor @NoArgsConstructor public cl

  • 利用json2POJO with Lombok 插件自动生成java类的操作

    前言 很多时候,我们定义接口或者调用别人的接口时,手里只有一份接口文档,文档中提供一段示例json格式的报文,我们需要根据json中的字段,挨个去定义java POJO 的字段属性. 属实费劲,且有时候万一手抖,个别字段填错了,就导致前后端联调不能一次性成功. 如果能有办法将json直接生成java POJO,岂不是能省去很多时间. 1.安装idea 插件 打开preferences → Plugins → marketplace → 输入:json2Pojo with Lombok,点击安装并

  • IntelliJ IDEA安装插件阿里巴巴Java开发手册(Alibaba Java Coding Guidelines)

    以前看到过个:Java开发手册(阿里巴巴-公开版),这是个pdf文档,里面描述了一些Java开发的规约,里面确实有很多好用的规约,要是在学校就有机会看看的话,那么,在毕业之后,实际工作中就会少很多坑.现在,阿里巴巴又一次对这个文档进行了升级,直接变成了一个插件.你需要的就是:知道有这么个插件,然后,还得安装这个插件,那么以后,你在写代码的时候,这个插件就会自动的纠正你在写代码的时候的一些很low的不规范代码. 下面看怎么在这个 IntelliJ IDEA 上安装这个插件. 通过Jetbrains

  • Java编程cas操作全面解析

    CAS 指的是现代 CPU 广泛支持的一种对内存中的共享数据进行操作的一种特殊指令.这个指令会对内存中的共享数据做原子的读写操作. 简单介绍一下这个指令的操作过程:首先,CPU 会将内存中将要被更改的数据与期望的值做比较.然后,当这两个值相等时,CPU 才会将内存中的数值替换为新的值.否则便不做操作.最后,CPU 会将旧的数值返回.这一系列的操作是原子的.它们虽然看似复杂,但却是 Java 5 并发机制优于原有锁机制的根本.简单来说,CAS 的含义是"我认为原有的值应该是什么,如果是,则将原有的

  • Java使用poi操作excel实例解析

    本文实例为大家分享了Java使用poi操作excel的具体代码,供大家参考,具体内容如下 依赖poi的jar包,pom.xml配置如下: <project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0h

  • Java连接并操作Sedna XML数据库的方法

    本文实例讲述了Java连接并操作Sedna XML数据库的方法.分享给大家供大家参考.具体分析如下: Sedna 是一个原生的XML数据库,提供了全功能的核心数据库服务,包括持久化存储.ACID事务.索引.安全.热备.UTF8等.实现了 W3C XQuery 规范,支持全文搜索以及节点级别的更新操作. import ru.ispras.sedna.driver.*; public class SednaClient { public static void main(String args[])

  • java客户端Jedis操作Redis Sentinel 连接池的实现方法

    pom.xml配置 <dependency> <groupId>org.springframework.data</groupId> <artifactId>spring-data-redis</artifactId> <version>1.0.2.RELEASE</version> </dependency> <dependency> <groupId>redis.clients<

  • java IO数据操作流、对象序列化、压缩流代码解析

    数据操作流 在io包中,提供了两个与平台无关的数据操作流: 数据输入流(DataInputStream) 数据输出流(DataOutputStream) 通常数据输出流会按一定格式将数据输出,再通过数据输入流按照一定格式将数据读入 DataOutputStream接口定义了一系列的writeXxx()的操作,可以写入各种数据类型的数据. 范例:使用数据操作流写入与读出数据 import java.io.DataOutputStream ; import java.io.File ; import

  • Java对象序列化操作详解

    本文实例讲述了Java对象序列化操作.分享给大家供大家参考,具体如下: 当两个进程在进行远程通信时,彼此可以发送各种类型的数据.无论是何种类型的数据,都会以二进制序列的形式在网络上传送.发送方需要把这个Java对象转换为字节序列,才能在网络上传送:接收方则需要把字节序列再恢复为Java对象. 只能将支持 java.io.Serializable 接口的对象写入流中.每个 serializable 对象的类都被编码,编码内容包括类名和类签名.对象的字段值和数组值,以及从初始对象中引用的其他所有对象

  • JS加密插件CryptoJS实现AES加密操作示例

    本文实例讲述了JS加密插件CryptoJS实现AES加密操作.分享给大家供大家参考,具体如下: 最近在做一个项目,考虑到数据的安全性,我们要给数据在传输过程中加密,防止一些恶意的操作以及爬虫抓取数据. 用到的库:CryptoJS 官方地址:https://code.google.com/archive/p/crypto-js/ 首先看看这个CryptoJS的目录结构 主要是两个文件夹,components和rollups 第一个是组件,第二个是汇总. 在汇总文件夹中的文件是在组件一个或多个文件夹

随机推荐