feat:新增字典表(初)

master
Jiang Peng 2024-04-26 14:13:53 +08:00
parent 639cb8159e
commit c5488049c1
10 changed files with 718 additions and 0 deletions

View File

@ -0,0 +1,40 @@
package com.muyu.etl.domain;
import com.muyu.common.core.web.domain.BaseEntity;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.util.List;
@Data
@NoArgsConstructor
@AllArgsConstructor
public class Dictionary extends BaseEntity {
/**
*
*/
private Long id;
/**
*
*/
private String dictionaryName;
/**
* key
*/
private String dictionaryKey;
/**
* ID
*/
private Long dataSourceId;
/**
*
*/
private List<DictionaryData> dictionaryDataList;
}

View File

@ -0,0 +1,35 @@
package com.muyu.etl.domain;
import com.muyu.common.core.web.domain.BaseEntity;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
@Data
@NoArgsConstructor
@AllArgsConstructor
public class DictionaryData extends BaseEntity {
private Long id;
/**
* Id
*/
private Long dictionaryId;
/**
*
*/
private String label;
/**
*
*/
private String val;
/**
*
*/
private Boolean isEdit = false;
}

View File

@ -0,0 +1,60 @@
package com.muyu.etl.mapper;
import com.muyu.etl.domain.DictionaryData;
import org.apache.ibatis.annotations.Param;
import java.util.List;
public interface DictionaryDataMapper {
/**
*
*
* @param id
* @return
*/
public DictionaryData selectDictionaryDataById(Long id);
/**
*
*
* @param dictionaryData
* @return
*/
public List<DictionaryData> selectDictionaryDataList(DictionaryData dictionaryData);
/**
*
*
* @param dictionaryData
* @return
*/
public int insertDictionaryData(DictionaryData dictionaryData);
/**
*
*
* @param dictionaryData
* @return
*/
public int updateDictionaryData(DictionaryData dictionaryData);
/**
*
*
* @param id
* @return
*/
public int deleteDictionaryDataById(Long id);
/**
*
*
* @param ids
* @return
*/
public int deleteDictionaryDataByIds(Long[] ids);
List<DictionaryData> getDictionaryDataList(@Param("dictionaryIds") List<Long> dictionaryIds);
}

View File

@ -0,0 +1,61 @@
package com.muyu.etl.mapper;
import com.muyu.etl.domain.Dictionary;
import org.apache.ibatis.annotations.Param;
import java.util.List;
public interface DictionaryMapper {
/**
*
*
* @param id
* @return
*/
public Dictionary selectDictionaryById(Long id);
/**
*
*
* @param dictionary
* @return
*/
public List<Dictionary> selectDictionaryList(Dictionary dictionary);
/**
*
*
* @param dictionary
* @return
*/
public int insertDictionary(Dictionary dictionary);
/**
*
*
* @param dictionary
* @return
*/
public int updateDictionary(Dictionary dictionary);
/**
*
*
* @param id
* @return
*/
public int deleteDictionaryById(Long id);
/**
*
*
* @param ids
* @return
*/
public int deleteDictionaryByIds(Long[] ids);
List<Dictionary> getDictionaryList(@Param("dataSourceId") Long dataSourceId);
}

View File

@ -0,0 +1,57 @@
package com.muyu.etl.service;
import com.muyu.etl.domain.DictionaryData;
import java.util.List;
public interface DictionaryDataService {
/**
*
*
* @param id
* @return
*/
public DictionaryData selectDictionaryDataById(Long id);
/**
*
*
* @param dictionaryData
* @return
*/
public List<DictionaryData> selectDictionaryDataList(DictionaryData dictionaryData);
/**
*
*
* @param dictionaryData
* @return
*/
public int insertDictionaryData(DictionaryData dictionaryData);
/**
*
*
* @param dictionaryData
* @return
*/
public int updateDictionaryData(DictionaryData dictionaryData);
/**
*
*
* @param ids
* @return
*/
public int deleteDictionaryDataByIds(Long[] ids);
/**
*
*
* @param id
* @return
*/
public int deleteDictionaryDataById(Long id);
}

View File

@ -0,0 +1,61 @@
package com.muyu.etl.service;
import com.muyu.common.core.domain.Result;
import com.muyu.etl.domain.Dictionary;
import java.util.List;
public interface DictionaryService {
/**
*
*
* @param id
* @return
*/
public Dictionary selectDictionaryById(Long id);
/**
*
*
* @param dictionary
* @return
*/
public List<Dictionary> selectDictionaryList(Dictionary dictionary);
/**
*
*
* @param dictionary
* @return
*/
public int insertDictionary(Dictionary dictionary);
/**
*
*
* @param dictionary
* @return
*/
public int updateDictionary(Dictionary dictionary);
/**
*
*
* @param ids
* @return
*/
public int deleteDictionaryByIds(Long[] ids);
/**
*
*
* @param id
* @return
*/
public int deleteDictionaryById(Long id);
Result getDictionaryList(Long dataSourceId);
}

View File

@ -0,0 +1,96 @@
package com.muyu.etl.service.impl;
import com.muyu.common.core.utils.DateUtils;
import com.muyu.common.security.utils.SecurityUtils;
import com.muyu.etl.domain.DictionaryData;
import com.muyu.etl.mapper.DictionaryDataMapper;
import com.muyu.etl.mapper.DictionaryMapper;
import com.muyu.etl.service.DictionaryDataService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;
@Service
public class DictionaryDataServiceImpl implements DictionaryDataService {
@Autowired
private DictionaryDataMapper dictionaryDataMapper;
/**
*
*
* @param id
* @return
*/
@Override
public DictionaryData selectDictionaryDataById(Long id)
{
return dictionaryDataMapper.selectDictionaryDataById(id);
}
/**
*
*
* @param dictionaryData
* @return
*/
@Override
public List<DictionaryData> selectDictionaryDataList(DictionaryData dictionaryData)
{
return dictionaryDataMapper.selectDictionaryDataList(dictionaryData);
}
/**
*
*
* @param dictionaryData
* @return
*/
@Override
public int insertDictionaryData(DictionaryData dictionaryData)
{
dictionaryData.setCreateTime(DateUtils.getNowDate());
dictionaryData.setCreateBy(SecurityUtils.getUsername());
return dictionaryDataMapper.insertDictionaryData(dictionaryData);
}
/**
*
*
* @param dictionaryData
* @return
*/
@Override
public int updateDictionaryData(DictionaryData dictionaryData)
{
dictionaryData.setUpdateTime(DateUtils.getNowDate());
dictionaryData.setUpdateBy(SecurityUtils.getUsername());
return dictionaryDataMapper.updateDictionaryData(dictionaryData);
}
/**
*
*
* @param ids
* @return
*/
@Override
public int deleteDictionaryDataByIds(Long[] ids)
{
return dictionaryDataMapper.deleteDictionaryDataByIds(ids);
}
/**
*
*
* @param id
* @return
*/
@Override
public int deleteDictionaryDataById(Long id)
{
return dictionaryDataMapper.deleteDictionaryDataById(id);
}
}

View File

@ -0,0 +1,118 @@
package com.muyu.etl.service.impl;
import java.util.List;
import com.muyu.common.core.domain.Result;
import com.muyu.common.core.utils.DateUtils;
import com.muyu.common.security.utils.SecurityUtils;
import com.muyu.etl.domain.DictionaryData;
import com.muyu.etl.mapper.DictionaryDataMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import com.muyu.etl.mapper.DictionaryMapper;
import com.muyu.etl.domain.Dictionary;
import com.muyu.etl.service.DictionaryService;
import org.springframework.transaction.annotation.Transactional;
/**
* Service
*
* @author ruoyi
* @date 2024-04-25
*/
@Service
public class DictionaryServiceImpl implements DictionaryService {
@Autowired
private DictionaryMapper dictionaryMapper;
@Autowired
private DictionaryDataMapper dictionaryDataMapper;
/**
*
*
* @param id
* @return
*/
@Override
public Dictionary selectDictionaryById(Long id) {
return dictionaryMapper.selectDictionaryById(id);
}
/**
*
*
* @param dictionary
* @return
*/
@Override
public List<Dictionary> selectDictionaryList(Dictionary dictionary) {
return dictionaryMapper.selectDictionaryList(dictionary);
}
/**
*
*
* @param dictionary
* @return
*/
@Override
public int insertDictionary(Dictionary dictionary) {
dictionary.setCreateTime(DateUtils.getNowDate());
dictionary.setCreateBy(SecurityUtils.getUsername());
return dictionaryMapper.insertDictionary(dictionary);
}
/**
*
*
* @param dictionary
* @return
*/
@Override
public int updateDictionary(Dictionary dictionary) {
dictionary.setUpdateTime(DateUtils.getNowDate());
dictionary.setUpdateBy(SecurityUtils.getUsername());
return dictionaryMapper.updateDictionary(dictionary);
}
/**
*
*
* @param ids
* @return
*/
@Override
public int deleteDictionaryByIds(Long[] ids) {
return dictionaryMapper.deleteDictionaryByIds(ids);
}
/**
*
*
* @param id
* @return
*/
@Override
public int deleteDictionaryById(Long id) {
return dictionaryMapper.deleteDictionaryById(id);
}
@Override
public Result getDictionaryList(Long dataSourceId) {
List<Dictionary> dictionaryList = dictionaryMapper.getDictionaryList(dataSourceId);
if (!dictionaryList.isEmpty()){
List<Long> longs = dictionaryList.stream()
.map(Dictionary::getId).toList();
List<DictionaryData> dictionaryDataList = dictionaryDataMapper.getDictionaryDataList(longs);
dictionaryList.stream()
.forEach(dictionary->{
dictionaryDataList.stream().filter(dictionaryData -> dictionaryData.getDictionaryId().equals(dictionary.getId()) ).toList();
dictionary.setDictionaryDataList(dictionaryDataList);
});
}
return Result.success(dictionaryList);
}
}

View File

@ -0,0 +1,98 @@
<?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.muyu.etl.mapper.DictionaryDataMapper">
<resultMap type="com.muyu.etl.domain.DictionaryData" id="DictionaryDataResult">
<result property="id" column="id" />
<result property="dictionaryId" column="dictionary_id" />
<result property="label" column="label" />
<result property="val" column="val" />
<result property="createBy" column="create_by" />
<result property="createTime" column="create_time" />
<result property="updateBy" column="update_by" />
<result property="updateTime" column="update_time" />
<result property="remark" column="remark" />
</resultMap>
<sql id="selectDictionaryDataVo">
select id, dictionary_id, label, val, create_by, create_time, update_by, update_time, remark from dictionarydata
</sql>
<select id="selectDictionaryDataList" parameterType="com.muyu.etl.domain.DictionaryData" resultMap="DictionaryDataResult">
<include refid="selectDictionaryDataVo"/>
<where>
<if test="dictionaryId != null "> and dictionary_id = #{dictionaryId}</if>
<if test="label != null and dictionaryTag != ''"> and label = #{label}</if>
<if test="val != null and dictionaryValue != ''"> and val = #{val}</if>
</where>
</select>
<select id="selectDictionaryDataById" parameterType="Long" resultMap="DictionaryDataResult">
<include refid="selectDictionaryDataVo"/>
where id = #{id}
</select>
<select id="getDictionaryDataList" resultType="com.muyu.etl.domain.DictionaryData">
<include refid="selectDictionaryDataVo"></include>
<where>
and dictionary_id in (
<foreach item="id" index="index" collection="dictionaryIds" separator=",">
#{id}
</foreach>
)
</where>
</select>
<insert id="insertDictionaryData" parameterType="com.muyu.etl.domain.DictionaryData" useGeneratedKeys="true" keyProperty="id">
insert into dictionarydata
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="dictionaryId != null">dictionary_id,</if>
<if test="label != null">label,</if>
<if test="val != null">val,</if>
<if test="createBy != null">create_by,</if>
<if test="createTime != null">create_time,</if>
<if test="updateBy != null">update_by,</if>
<if test="updateTime != null">update_time,</if>
<if test="remark != null">remark,</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="dictionaryId != null">#{dictionaryId},</if>
<if test="label != null">#{label},</if>
<if test="val != null">#{val},</if>
<if test="createBy != null">#{createBy},</if>
<if test="createTime != null">#{createTime},</if>
<if test="updateBy != null">#{updateBy},</if>
<if test="updateTime != null">#{updateTime},</if>
<if test="remark != null">#{remark},</if>
</trim>
</insert>
<update id="updateDictionaryData" parameterType="com.muyu.etl.domain.DictionaryData">
update dictionarydata
<trim prefix="SET" suffixOverrides=",">
<if test="dictionaryId != null">dictionary_id = #{dictionaryId},</if>
<if test="label != null">label = #{label},</if>
<if test="val != null">val = #{val},</if>
<if test="createBy != null">create_by = #{createBy},</if>
<if test="createTime != null">create_time = #{createTime},</if>
<if test="updateBy != null">update_by = #{updateBy},</if>
<if test="updateTime != null">update_time = #{updateTime},</if>
<if test="remark != null">remark = #{remark},</if>
</trim>
where id = #{id}
</update>
<delete id="deleteDictionaryDataById" parameterType="Long">
delete from dictionarydata where id = #{id}
</delete>
<delete id="deleteDictionaryDataByIds" parameterType="String">
delete from dictionarydata where id in
<foreach item="id" collection="array" open="(" separator="," close=")">
#{id}
</foreach>
</delete>
</mapper>

View File

@ -0,0 +1,92 @@
<?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.muyu.etl.mapper.DictionaryMapper">
<resultMap type="com.muyu.etl.domain.Dictionary" id="DictionaryResult">
<result property="id" column="id" />
<result property="dictionaryName" column="dictionary_name" />
<result property="dictionaryKey" column="dictionary_key" />
<result property="dataSourceId" column="data_source_id" />
<result property="createBy" column="create_by" />
<result property="createTime" column="create_time" />
<result property="updateBy" column="update_by" />
<result property="updateTime" column="update_time" />
<result property="remark" column="remark" />
</resultMap>
<sql id="selectDictionaryVo">
select id, dictionary_name, dictionary_key,data_source_id, create_by, create_time, update_by, update_time, remark from dictionary
</sql>
<select id="selectDictionaryList" parameterType="com.muyu.etl.domain.Dictionary" resultMap="DictionaryResult">
<include refid="selectDictionaryVo"/>
<where>
<if test="dictionaryName != null and dictionaryName != ''"> and dictionary_name like concat('%', #{dictionaryName}, '%')</if>
<if test="dictionaryKey != null and dictionaryKey != ''"> and dictionary_key = #{dictionaryKey}</if>
<if test="dataSourceId != null"> and data_source_id = #{dataSourceId}</if>
</where>
</select>
<select id="selectDictionaryById" parameterType="Long" resultMap="DictionaryResult">
<include refid="selectDictionaryVo"/>
where id = #{id}
</select>
<select id="getDictionaryList" resultType="com.muyu.etl.domain.Dictionary">
<include refid="selectDictionaryVo"></include>
<where>
and data_source_id = #{dataSourceId}
</where>
</select>
<insert id="insertDictionary" parameterType="com.muyu.etl.domain.Dictionary" useGeneratedKeys="true" keyProperty="id">
insert into dictionary
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="dictionaryName != null">dictionary_name,</if>
<if test="dictionaryKey != null">dictionary_key,</if>
<if test="dataSourceId != null">data_source_id,</if>
<if test="createBy != null">create_by,</if>
<if test="createTime != null">create_time,</if>
<if test="updateBy != null">update_by,</if>
<if test="updateTime != null">update_time,</if>
<if test="remark != null">remark,</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="dictionaryName != null">#{dictionaryName},</if>
<if test="dictionaryKey != null">#{dictionaryKey},</if>
<if test="dataSourceId != null">#{dataSourceId},</if>
<if test="createBy != null">#{createBy},</if>
<if test="createTime != null">#{createTime},</if>
<if test="updateBy != null">#{updateBy},</if>
<if test="updateTime != null">#{updateTime},</if>
<if test="remark != null">#{remark},</if>
</trim>
</insert>
<update id="updateDictionary" parameterType="com.muyu.etl.domain.Dictionary">
update dictionary
<trim prefix="SET" suffixOverrides=",">
<if test="dictionaryName != null">dictionary_name = #{dictionaryName},</if>
<if test="dictionaryKey != null">dictionary_key = #{dictionaryKey},</if>
<if test="dataSourceId != null">data_source_id = #{dataSourceId},</if>
<if test="createBy != null">create_by = #{createBy},</if>
<if test="createTime != null">create_time = #{createTime},</if>
<if test="updateBy != null">update_by = #{updateBy},</if>
<if test="updateTime != null">update_time = #{updateTime},</if>
<if test="remark != null">remark = #{remark},</if>
</trim>
where id = #{id}
</update>
<delete id="deleteDictionaryById" parameterType="Long">
delete from dictionary where id = #{id}
</delete>
<delete id="deleteDictionaryByIds" parameterType="String">
delete from dictionary where id in
<foreach item="id" collection="array" open="(" separator="," close=")">
#{id}
</foreach>
</delete>
</mapper>