<?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.cku.oa.groomer.dao.GroomerForeignRegisterDao">
    
	<sql id="groomerForeignRegisterColumns">
		a.id AS "id",
		a.certified_no AS "certifiedNo",
		a.register_no AS "registerNo",
		a.name AS "name",
		a.breed AS "breed",
		a.result AS "result",
		a.level AS "level",
		a.category AS "category",
		a.country AS "country",
		a.specific_date AS "specificDate",
		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="groomerForeignRegisterJoins">
	</sql>
    
	<select id="get" resultType="GroomerForeignRegister">
		SELECT 
			<include refid="groomerForeignRegisterColumns"/>
		FROM groomer_foreign_register a
		<include refid="groomerForeignRegisterJoins"/>
		WHERE a.id = #{id}
	</select>
	
	<select id="findList" resultType="GroomerForeignRegister">
		SELECT 
			<include refid="groomerForeignRegisterColumns"/>
		FROM groomer_foreign_register a
		<include refid="groomerForeignRegisterJoins"/>
		<where>
			a.del_flag = #{DEL_FLAG_NORMAL}
			<if test="name != null and name != ''">
				AND a.name LIKE concat('%',#{name},'%')
			</if>
			<if test="registerNo != null and registerNo != ''">
				AND a.register_no LIKE concat('%',#{registerNo},'%')
			</if>
			<if test="name != null and name != ''">
				AND a.name LIKE concat('%',#{name},'%')
			</if>
			<if test="breed != null and breed != ''">
				AND a.breed LIKE concat('%',#{breed},'%')
			</if>
			<if test="level != null and level != ''">
				AND a.level = #{level}
			</if>
			<if test="result != null and result != ''">
				AND a.result = #{result}
			</if>
			<if test="category != null and category != ''">
				AND a.category = #{category}
			</if>
			<if test="specificDateStr != null and specificDateStr != ''">
				AND date_format(a.specific_date, '%Y-%m') = #{specificDateStr}
			</if>
			<if test="country != null and country != ''">
				AND a.country = #{country}
			</if>
		</where>
		ORDER BY DATE_FORMAT(a.specific_date, '%Y') ASC,
    SUBSTRING_INDEX(SUBSTRING_INDEX(a.certified_no, '-', -2),'-',1) ASC,
    SUBSTRING_INDEX(a.certified_no, '-', -1) ASC
	</select>
	
	<select id="findAllList" resultType="GroomerForeignRegister">
		SELECT 
			<include refid="groomerForeignRegisterColumns"/>
		FROM groomer_foreign_register a
		<include refid="groomerForeignRegisterJoins"/>
		<where>
			a.del_flag = #{DEL_FLAG_NORMAL}
		</where>		
		<choose>
			<when test="page !=null and page.orderBy != null and page.orderBy != ''">
				ORDER BY ${page.orderBy}
			</when>
			<otherwise>
				ORDER BY a.update_date DESC
			</otherwise>
		</choose>
	</select>
	
	<insert id="insert">
		INSERT INTO groomer_foreign_register(
			id,
			certified_no,
			register_no,
			name,
			breed,
			result,
			level,
			category,
			country,
			specific_date,
			create_by,
			create_date,
			update_by,
			update_date,
			remarks,
			del_flag
		) VALUES (
			#{id},
			#{certifiedNo},
			#{registerNo},
			#{name},
			#{breed},
			#{result},
			#{level},
			#{category},
			#{country},
			#{specificDate},
			#{createBy.id},
			#{createDate},
			#{updateBy.id},
			#{updateDate},
			#{remarks},
			#{delFlag}
		)
	</insert>
	
	<update id="update">
		UPDATE groomer_foreign_register SET 	
			certified_no = #{certifiedNo},
			register_no = #{registerNo},
			name = #{name},
			breed = #{breed},
			result = #{result},
			level = #{level},
			category = #{category},
			country = #{country},
			specific_date = #{specificDate},
			update_by = #{updateBy.id},
			update_date = #{updateDate},
			remarks = #{remarks}
		WHERE id = #{id}
	</update>
	
	<update id="delete">
		UPDATE groomer_foreign_register SET 
			del_flag = #{DEL_FLAG_DELETE}
		WHERE id = #{id}
	</update>
	
</mapper>