RegBaseElementCodeDao.xml 3.98 KB
<?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.thinkgem.jeesite.modules.reg.dao.base.RegBaseElementCodeDao">
    
	<sql id="regBaseElementCodeColumns">
		a.id AS "id",
		a.parent_id AS "parent.id",
		a.parent_ids AS "parentIds",
		a.name AS "name",
		a.sort AS "sort",
		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",
		a.element_code AS "elementCode",
		a.element_name AS "elementName",
		a.element_type AS "elementType"
	</sql>
	
	<sql id="regBaseElementCodeJoins">
	</sql>
    
	<select id="get" resultType="RegBaseElementCode">
		SELECT 
			<include refid="regBaseElementCodeColumns"/>
		FROM reg_base_element_code a
		<include refid="regBaseElementCodeJoins"/>
		WHERE a.id = #{id}
	</select>
	
	<select id="findList" resultType="RegBaseElementCode">
		SELECT 
			<include refid="regBaseElementCodeColumns"/>
		FROM reg_base_element_code a
		<include refid="regBaseElementCodeJoins"/>
		<where>
			a.del_flag = #{DEL_FLAG_NORMAL}
			<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>
			<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="elementName != null and elementName != ''">
				AND a.element_name LIKE 
					<if test="dbName == 'oracle'">'%'||#{elementName}||'%'</if>
					<if test="dbName == 'mssql'">'%'+#{elementName}+'%'</if>
					<if test="dbName == 'mysql'">concat('%',#{elementName},'%')</if>
			</if>
		</where>
		ORDER BY a.sort ASC
	</select>
	
	<select id="findAllList" resultType="RegBaseElementCode">
		SELECT 
			<include refid="regBaseElementCodeColumns"/>
		FROM reg_base_element_code a
		<include refid="regBaseElementCodeJoins"/>
		<where>
			a.del_flag = #{DEL_FLAG_NORMAL}
		</where>
		ORDER BY a.sort ASC
	</select>
	
	<select id="findByParentIdsLike" resultType="RegBaseElementCode">
		SELECT
			a.id,
			a.parent_id AS "parent.id",
			a.parent_ids
		FROM reg_base_element_code a
		<include refid="regBaseElementCodeJoins"/>
		<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 reg_base_element_code(
			id,
			parent_id,
			parent_ids,
			name,
			sort,
			create_by,
			create_date,
			update_by,
			update_date,
			remarks,
			del_flag,
			element_code,
			element_name,
			element_type
		) VALUES (
			#{id},
			#{parent.id},
			#{parentIds},
			#{name},
			#{sort},
			#{createBy.id},
			#{createDate},
			#{updateBy.id},
			#{updateDate},
			#{remarks},
			#{delFlag},
			#{elementCode},
			#{elementName},
			#{elementType}
		)
	</insert>
	
	<update id="update">
		UPDATE reg_base_element_code SET 	
			parent_id = #{parent.id},
			parent_ids = #{parentIds},
			name = #{name},
			sort = #{sort},
			update_by = #{updateBy.id},
			update_date = #{updateDate},
			remarks = #{remarks},
			element_name = #{elementName},
			element_type = #{elementType}
		WHERE id = #{id}
	</update>
	
	<update id="updateParentIds">
		UPDATE reg_base_element_code SET 
			parent_id = #{parent.id}, 
			parent_ids = #{parentIds}
		WHERE id = #{id}
	</update>
	
	<update id="delete">
		UPDATE reg_base_element_code SET 
			del_flag = #{DEL_FLAG_DELETE}
		WHERE id = #{id} OR parent_ids LIKE 
					<if test="dbName == 'oracle'">'%,'||#{id}||',%'</if>
					<if test="dbName == 'mysql'">CONCAT('%,', #{id}, ',%')</if> 
	</update>
	
</mapper>