<?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.jeeplus.modules.test.dao.tree.TestTreeDao">
|
|
<sql id="testTreeColumns">
|
a.id AS "id",
|
a.name AS "name",
|
a.sort AS "sort",
|
a.parent_id AS "parent.id",
|
a.parent_ids AS "parentIds",
|
a.create_by AS "createBy.id",
|
a.create_date AS "createDate",
|
a.update_by AS "updateBy.id",
|
a.update_date AS "updateDate",
|
a.remarks AS "remarks",
|
a.del_flag AS "delFlag"
|
</sql>
|
|
<sql id="testTreeJoins">
|
</sql>
|
|
<select id="get" resultType="TestTree">
|
SELECT
|
<include refid="testTreeColumns"/>
|
FROM test_tree a
|
<include refid="testTreeJoins"/>
|
WHERE a.id = #{id}
|
</select>
|
|
<select id="findList" resultType="TestTree">
|
SELECT
|
<include refid="testTreeColumns"/>
|
FROM test_tree a
|
<include refid="testTreeJoins"/>
|
<where>
|
a.del_flag = #{DEL_FLAG_NORMAL}
|
<if test="name != null and name != ''">
|
AND a.name LIKE
|
<if test="dbName == 'oracle'">'%'||#{name}||'%'</if>
|
<if test="dbName == 'mssql'">'%'+#{name}+'%'</if>
|
<if test="dbName == 'mysql'">concat('%',#{name},'%')</if>
|
</if>
|
<if test="parent != null and parent.id != null and parent.id != ''">
|
AND a.parent_id = #{parent.id}
|
</if>
|
<if test="parentIds != null and parentIds != ''">
|
AND a.parent_ids LIKE
|
<if test="dbName == 'oracle'">'%'||#{parentIds}||'%'</if>
|
<if test="dbName == 'mssql'">'%'+#{parentIds}+'%'</if>
|
<if test="dbName == 'mysql'">concat('%',#{parentIds},'%')</if>
|
</if>
|
</where>
|
ORDER BY a.sort ASC
|
</select>
|
|
<select id="findAllList" resultType="TestTree">
|
SELECT
|
<include refid="testTreeColumns"/>
|
FROM test_tree a
|
<include refid="testTreeJoins"/>
|
<where>
|
a.del_flag = #{DEL_FLAG_NORMAL}
|
</where>
|
ORDER BY a.sort ASC
|
</select>
|
|
<select id="findByParentIdsLike" resultType="TestTree">
|
SELECT
|
a.id,
|
a.parent_id AS "parent.id",
|
a.parent_ids
|
FROM test_tree a
|
<include refid="testTreeJoins"/>
|
<where>
|
a.del_flag = #{DEL_FLAG_NORMAL}
|
AND a.parent_ids LIKE #{parentIds}
|
</where>
|
ORDER BY a.sort ASC
|
</select>
|
|
<insert id="insert">
|
INSERT INTO test_tree(
|
id,
|
name,
|
sort,
|
parent_id,
|
parent_ids,
|
create_by,
|
create_date,
|
update_by,
|
update_date,
|
remarks,
|
del_flag
|
) VALUES (
|
#{id},
|
#{name},
|
#{sort},
|
#{parent.id},
|
#{parentIds},
|
#{createBy.id},
|
#{createDate},
|
#{updateBy.id},
|
#{updateDate},
|
#{remarks},
|
#{delFlag}
|
)
|
</insert>
|
|
<update id="update">
|
UPDATE test_tree SET
|
name = #{name},
|
sort = #{sort},
|
parent_id = #{parent.id},
|
parent_ids = #{parentIds},
|
update_by = #{updateBy.id},
|
update_date = #{updateDate},
|
remarks = #{remarks}
|
WHERE id = #{id}
|
</update>
|
|
<update id="updateParentIds">
|
UPDATE test_tree SET
|
parent_id = #{parent.id},
|
parent_ids = #{parentIds}
|
WHERE id = #{id}
|
</update>
|
|
<!--物理删除-->
|
<update id="delete">
|
DELETE FROM test_tree
|
WHERE id = #{id} OR parent_ids LIKE '%,'||#{id}||',%'
|
</update>
|
|
<!--逻辑删除-->
|
<update id="deleteByLogic">
|
UPDATE test_tree SET
|
del_flag = #{DEL_FLAG_DELETE}
|
WHERE id = #{id} OR parent_ids LIKE '%,'||#{id}||',%'
|
</update>
|
|
</mapper>
|