<?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  * 
              FROM  (
            SELECT ROWNUM RNUM, ALL_LIST.* 
              FROM  (
		            SELECT A.LOGIN_ID USER_ID, 
		                   A.USR_NM USER_NM, 
		                   A.DEPT_ID GROUP_ID,
		                   A.USR_TP_CD MBER_TY_CODE,		                   
		                   (SELECT CD_NM FROM SNS_COMMON_CODE WHERE CD=A.USR_TP_CD AND UP_CD = 'USR_TP_CD') 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 '%'||#searchKeyword#||'%'
                </isEqual>
                <isEqual prepend="AND" property="searchCondition" compareValue="2">
                       A.USR_NM LIKE '%'||#searchKeyword#||'%'
                </isEqual>
                <isEqual prepend="AND" property="searchCondition" compareValue="3">
                       A.DEPT_ID = #searchKeyword#
                </isEqual>
            </isNotEmpty>
            <![CDATA[ 
                    ) ALL_LIST
                    ) Z
             WHERE  RNUM  > #firstIndex#
               AND  RNUM <= #firstIndex# + #recordCountPerPage#
             ]]>  
    </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#
                 , RGS_ID=#rgsId#
                 , RGS_DE=TO_CHAR(SYSDATE, 'YYYYMMDDHH24MISS')
             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 '%'||#searchKeyword#||'%'
                </isEqual>
                <isEqual prepend="AND" property="searchCondition" compareValue="2">
                       A.USR_NM LIKE '%'||#searchKeyword#||'%'
                </isEqual>
                <isEqual prepend="AND" property="searchCondition" compareValue="3">
                       A.DEPT_ID = #searchKeyword#
                </isEqual>
            </isNotEmpty>
    </select>

</sqlMap>
