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

TOC

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);
    }

}




posted @ 2020-07-15 09:18  紫月java  阅读(1405)  评论(0编辑  收藏  举报