<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMap PUBLIC "-//iBATIS.com//DTD SQL Map 2.0//EN" "http://www.ibatis.com/dtd/sql-map-2.dtd">

<sqlMap namespace="AuthorGroup">

	<typeAlias  alias="egovMap" type="egovframework.rte.psl.dataaccess.util.EgovMap"/>
    <typeAlias  alias="AuthorGroupVO" type="egovframework.com.sec.rgm.service.AuthorGroupVO"/>
    <typeAlias  alias="AuthorGroup" type="egovframework.com.sec.rgm.service.AuthorGroup"/>

    <resultMap id="authorGroup" class="egovframework.com.sec.rgm.service.AuthorGroupVO">
        <result property="userId" column="USER_ID" columnIndex="1"/>
        <result property="userNm" column="USER_NM" columnIndex="2"/>
        <result property="groupId" column="GROUP_ID" columnIndex="3"/>
        <result property="mberTyCode" column="MBER_TY_CODE" columnIndex="4"/>
        <result property="mberTyNm" column="MBER_TY_NM" columnIndex="5"/>
        <result property="authorCode" column="AUTHOR_CODE" columnIndex="6"/>
        <result property="regYn" column="REG_YN" columnIndex="8"/>
        <result property="uniqId" column="ESNTL_ID" columnIndex="9"/>
    </resultMap>

    <select id="authorGroupDAO.selectAuthorGroupList" parameterClass="AuthorGroupVO" resultMap="authorGroup">
            SELECT A.LOGIN_ID USER_ID, 
                   A.USR_NM USER_NM, 
                   A.DEPT_ID GROUP_ID,
                   '' MBER_TY_CODE,
                   '' MBER_TY_NM,
                   B.AUTHOR_CODE, 
                   (CASE WHEN B.SCRTY_DTRMN_TRGET_ID IS NULL THEN 'N'
                         ELSE 'Y' 
                     END) AS REG_YN,
                   A.USR_ID ESNTL_ID
              FROM  SNS_USER  A LEFT OUTER JOIN COMTNEMPLYRSCRTYESTBS B
                	ON A.USR_ID = B.SCRTY_DTRMN_TRGET_ID
             WHERE 1 = 1    
            <isNotEmpty property="searchKeyword">
                <isEqual prepend="AND" property="searchCondition" compareValue="1">
                       A.LOGIN_ID LIKE CONCAT('%' , #searchKeyword#, '%')
                </isEqual>
	            <isEqual prepend="AND" property="searchCondition" compareValue="2">
	                   A.USR_NM LIKE CONCAT('%' , #searchKeyword#, '%')
	            </isEqual>
            </isNotEmpty>
             LIMIT #recordCountPerPage# OFFSET #firstIndex#
    </select>

	<insert id="authorGroupDAO.insertAuthorGroup" parameterClass="AuthorGroup">
		<![CDATA[
			INSERT INTO COMTNEMPLYRSCRTYESTBS 
				  ( SCRTY_DTRMN_TRGET_ID
                  , MBER_TY_CODE
				  , AUTHOR_CODE)
		   VALUES ( #uniqId#
                  , #mberTyCode#
                  , #authorCode#)
		]]>
	</insert>

	<update id="authorGroupDAO.updateAuthorGroup" parameterClass="AuthorGroup">
		<![CDATA[
			UPDATE COMTNEMPLYRSCRTYESTBS 
			   SET AUTHOR_CODE=#authorCode#
		  	 WHERE SCRTY_DTRMN_TRGET_ID=#uniqId#
		]]>
	</update>
	
	<update id="authorGroupDAO.updateAuthorGroupUser" parameterClass="AuthorGroup">
        <![CDATA[
            UPDATE SNS_USER 
               SET AUTH_CODE=#authorCode#
             WHERE USR_ID=#uniqId#
        ]]>
    </update>

	<delete id="authorGroupDAO.deleteAuthorGroup">
		<![CDATA[
			DELETE FROM COMTNEMPLYRSCRTYESTBS 
			 WHERE SCRTY_DTRMN_TRGET_ID=#uniqId#
		]]>
	</delete>

	<select id="authorGroupDAO.selectAuthorGroupListTotCnt" parameterClass="AuthorGroupVO" resultClass="int">
            SELECT COUNT(*) AS totcnt
              FROM SNS_USER A LEFT OUTER JOIN COMTNEMPLYRSCRTYESTBS B
                ON A.USR_ID = B.SCRTY_DTRMN_TRGET_ID
             WHERE 1 = 1   
            <isNotEmpty property="searchKeyword">
                <isEqual prepend="AND" property="searchCondition" compareValue="1">
                       A.LOGIN_ID LIKE CONCAT('%' , #searchKeyword#, '%')
                </isEqual>
                <isEqual prepend="AND" property="searchCondition" compareValue="2">
                       A.USR_NM LIKE CONCAT('%' , #searchKeyword#, '%')
                </isEqual>
            </isNotEmpty>
	</select>

</sqlMap>
