使用idea插件進(jìn)行java代碼生成的操作
java代碼生成
使用idea的插件codehelper.generator進(jìn)行代碼生成,可以根據(jù)entity,生成對應(yīng)的
1、建表sql語句
2、dao.java文件
3、dao.xml文件
4、service.java文件
同時(shí)這個(gè)插件還能在new了entity之后生成所有的set方法
多次生成,不會影響自己手動(dòng)添加的代碼
安裝
安裝插件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了之后在下一行:點(diǎn)擊tool--codeHelper--GenAllSetter

生成代碼
點(diǎn)擊tool--codeHelper--tox Boxes--在彈窗中輸入entity,多個(gè)使用'|'分隔,就會在當(dāng)前文件夾生成代碼

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);
}
}
補(bǔ)充知識:IDEA 新建junit單元測試
1. 新建test目錄
在src同級目錄下新建test文件夾,右鍵test文件夾設(shè)置為Test Source Root

2. 創(chuàng)建測試類
選中要?jiǎng)?chuàng)建單元測試的實(shí)現(xiàn)類,并將焦點(diǎn)放在編輯器中(鼠標(biāo)在編輯器中點(diǎn)擊一下),菜單欄選擇Navigate----Test(Mac快捷鍵:Cmd+shift+t):

選擇創(chuàng)建新的測試:

選中要測試的方法,以及生成@Before:

這樣之后就會在test下新建一個(gè)測試類:

3. 測試函數(shù)介紹
測試類中包含兩個(gè)函數(shù):
@Before
public void setUp() throws Exception
這個(gè)是測試方法執(zhí)行前執(zhí)行的函數(shù),假如在測試方法中需要使用該類中的成員變量,那么可以在該函數(shù)中定義該成員變量。
@Test
public void findUserById() throws Exception
這個(gè)便是測試函數(shù)。點(diǎn)擊編輯器左列的小工具即可發(fā)起測試。

以上這篇使用idea插件進(jìn)行java代碼生成的操作就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java下載文件中文文件名亂碼的解決方案(文件名包含很多%)
Java下載文件時(shí),文件名中文亂碼問題通常是由于編碼不正確導(dǎo)致的,使用`URLEncoder.encode(filepath, "UTF-8")`可以解決在提示下載框中正確顯示漢字文件名的問題,但在選擇直接打開時(shí),文件名會變成亂碼,解決這個(gè)問題的方法2025-02-02
從ElasticSearch中刪除數(shù)據(jù)的幾種常見方式
這篇文章主要給大家介紹了關(guān)于從ElasticSearch中刪除數(shù)據(jù)的幾種常見方式,在Elasticsearch中刪除數(shù)據(jù)可以通過刪除索引或刪除文檔兩種方式實(shí)現(xiàn),需要的朋友可以參考下2024-10-10
詳解Spring?Security?捕獲?filter?層面異常返回我們自定義的內(nèi)容
Spring?的異常會轉(zhuǎn)發(fā)到?BasicErrorController?中進(jìn)行異常寫入,然后才會返回客戶端。所以,我們可以在?BasicErrorController?對?filter異常進(jìn)行捕獲并處理,下面通過本文給大家介紹Spring?Security?捕獲?filter?層面異常,返回我們自定義的內(nèi)容,感興趣的朋友一起看看吧2022-05-05
Java動(dòng)態(tài)獲取實(shí)現(xiàn)類的方式詳解
這篇文章主要介紹了Java動(dòng)態(tài)獲取實(shí)現(xiàn)類的方式詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作有一定的參考價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2024-01-01
Mybatis通過數(shù)據(jù)庫表自動(dòng)生成實(shí)體類和xml映射文件
這篇文章主要介紹了Mybatis通過數(shù)據(jù)庫表自動(dòng)生成實(shí)體類和xml映射文件的操作,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07
Mybatis多表關(guān)聯(lián)查詢的實(shí)現(xiàn)(DEMO)
本節(jié)要實(shí)現(xiàn)的是多表關(guān)聯(lián)查詢的簡單demo。場景是根據(jù)id查詢某商品分類信息,并展示該分類下的商品列表,需要的朋友可以參考下2017-02-02

