<?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">
<!-- 
	수정일                 수정자                          수정내용
  =========     =======    =================================================
  2011.10.17   	서준식     	 	OCCRRNC_DE 컬럼과 날짜 비교문에 RTRIM 함수 적용

-->
<sqlMap namespace="WebLog">

	<typeAlias  alias="egovMap" type="egovframework.rte.psl.dataaccess.util.EgovMap"/>
	<!-- 웹로그 VO -->
	<typeAlias  alias="webLog" type="egovframework.com.sym.log.wlg.service.WebLog"/>

	<!-- 웹로그 맵 -->
	<resultMap id="WebLogVO" class="egovframework.com.sym.log.wlg.service.WebLog">
		<result property="requstId" column="REQUST_ID"/>
		<result property="occrrncDe" column="OCCRRNC_DE"/>
		<result property="url" column="URL"/>
		<result property="rqesterIp" column="RQESTER_IP"/>
		<result property="rqesterId" column="RQESTER_ID"/>
		<result property="rqsterNm" column="RQESTER_NM"/>
	</resultMap>

	<!-- 웹 로그 등록 -->
	<insert id="WebLogDAO.logInsertWebLog" parameterClass="webLog" >
		<![CDATA[
			INSERT INTO COMTNWEBLOG
				( REQUST_ID
				  , URL
				  , RQESTER_ID
				  , RQESTER_IP
				  , OCCRRNC_DE )
			VALUES ( #requstId#
				  , #url#
				  , #rqesterId#
				  , #rqesterIp#
				  , TO_CHAR(sysdate, 'YYYYMMDD'))
		]]>
	</insert>

	<!-- 웹 로그 상세 조회 -->
	<select id="WebLogDAO.selectWebLog" parameterClass="webLog" resultMap="WebLogVO">
		<![CDATA[
			SELECT
				  a.REQUST_ID
				, a.OCCRRNC_DE
				, a.URL
				, a.RQESTER_IP
				, a.RQESTER_ID
				, b.USER_NM AS RQESTER_NM
			FROM
				COMTNWEBLOG a
			LEFT OUTER JOIN COMVNUSERMASTER b
				ON a.RQESTER_ID = b.ESNTL_ID
			WHERE
				a.REQUST_ID = #requstId#
			]]>
	</select>

	<!-- 웹 로그 목록 조회 -->
	<select id="WebLogDAO.selectWebLogInf" parameterClass="webLog" resultMap="WebLogVO">
		<![CDATA[
		SELECT * FROM ( SELECT rownum rn, TB.* FROM (
			SELECT
				  a.REQUST_ID
				, a.OCCRRNC_DE
				, a.URL
				, a.RQESTER_IP
				, a.RQESTER_ID
				, b.USER_NM AS RQESTER_NM
			FROM
				COMTNWEBLOG a
			LEFT OUTER JOIN COMVNUSERMASTER b
				ON a.RQESTER_ID = b.ESNTL_ID
			WHERE
				1 = 1
			]]>
			<isNotEmpty prepend="AND" property="searchWrd">
				<![CDATA[	a.URL LIKE '%' || #searchWrd# || '%' ]]>
			</isNotEmpty>
			<isNotEmpty prepend="AND" property="searchBgnDe">
				<![CDATA[	a.OCCRRNC_DE BETWEEN #searchBgnDe# AND #searchEndDe# ]]>
			</isNotEmpty>
		<![CDATA[
			ORDER BY a.OCCRRNC_DE DESC
			) TB ) Z WHERE rn BETWEEN #firstIndex# + 1 AND #firstIndex# + #recordCountPerPage#
		]]>
	</select>

	<!-- 웹 로그 총건수 -->
	<select id="WebLogDAO.selectWebLogInfCnt"  parameterClass="webLog"  resultClass="java.lang.Integer">
		<![CDATA[
			SELECT COUNT(a.REQUST_ID) as cnt
			FROM
				COMTNWEBLOG a
			LEFT OUTER JOIN COMVNUSERMASTER b
				ON a.RQESTER_ID = b.ESNTL_ID
			WHERE
				1 = 1
			]]>
			<isNotEmpty prepend="AND" property="searchWrd">
				<![CDATA[ 	a.URL LIKE '%' || #searchWrd# || '%'  ]]>
			</isNotEmpty>
			<isNotEmpty prepend="AND" property="searchBgnDe">
				<![CDATA[ 	a.OCCRRNC_DE BETWEEN #searchBgnDe# AND #searchEndDe#  ]]>
			</isNotEmpty>
	</select>

	<!-- 웹 로그 전날 로그 요약 등록 -->
	<insert id="WebLogDAO.logInsertWebLogSummary">
		<![CDATA[
			INSERT INTO COMTSWEBLOGSUMMARY
			SELECT b.OCCRRNC_DE
			     , b.URL
			     , COUNT(b.OCCRRNC_DE) AS RDCNT
			  FROM COMTNWEBLOG b
			 WHERE NOT EXISTS (SELECT c.OCCRRNC_DE
			                     FROM COMTSWEBLOGSUMMARY c
			                    WHERE RTRIM(c.OCCRRNC_DE) = TO_CHAR((SYSDATE - 1), 'YYYYMMDD')
			                  )
			   AND RTRIM(b.OCCRRNC_DE) = TO_CHAR((SYSDATE - 1), 'YYYYMMDD')
			 GROUP BY b.OCCRRNC_DE
				    , b.URL

		]]>
	</insert>

	<!-- 웹 로그 6개월전 로그 삭제 -->
	<delete id="WebLogDAO.logDeleteWebLogSummary">
		<![CDATA[
			DELETE FROM COMTNWEBLOG
			 WHERE RTRIM(OCCRRNC_DE) < TO_CHAR((SYSDATE - 210), 'YYYYMMDD')

		]]>
	</delete>

</sqlMap>

