BoardMapper.xml > SPRING1

본문 바로가기
사이트 내 전체검색

SPRING1

BoardMapper.xml

페이지 정보

profile_image
작성자 관리자
댓글 0건 조회 61회 작성일 24-07-30 15:37

본문

<?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.pkt.mapper.BoardMapper">


<select id="getList" resultType="com.pkt.model.BoardVO">

<!-- <![CDATA[ ]] 쓰는 이유 -->

<!-- sql 구문안에 비교 연산자가 들어갈 경우(특수문자) 문자열로 인식하게 하기 위해서 ... -->

<![CDATA[

select * from tbl_board where bno > 0

]]>

</select>


<select id="listPage" resultType="com.pkt.model.BoardVO">

<![CDATA[

select * from tbl_board where bno > 0 order by bno desc limit #{page}, 5

]]>

</select>


<select id="listCriteria" resultType="com.pkt.model.BoardVO">

  <![CDATA[

select * from tbl_board where bno > 0 order by bno desc limit #{pageStart}, #{perPageNum}

  ]]>

</select>


<select id="countPaging" resultType="int">

  <![CDATA[

select count(bno) from tbl_board where bno > 0

  ]]>

</select>


<insert id="create">

insert into tbl_board (title, content, writer) values (#{title},#{content}, #{writer})

</insert>


<select id="read" resultType="com.pkt.model.BoardVO">

select * from tbl_board where bno = #{bno}

</select>


<update id="updateViewCnt">

update tbl_board set viewcnt = viewcnt + 1 where bno = #{bno}

</update>


<update id="update">

update tbl_board set title =#{title}, content =#{content} where bno = #{bno}

</update>


<delete id="delete">

delete from tbl_board where bno = #{bno}

</delete>


<!-- search -->

<select id="listSearch" resultType="com.pkt.model.BoardVO">

  <![CDATA[

select * from tbl_board where bno > 0 

  ]]> 


<include refid="search"></include> 


  <![CDATA[

order by bno desc limit #{pageStart}, #{perPageNum}

  ]]>

</select>


<select id="listSearchCount" resultType="int">

  <![CDATA[

select count(bno) from tbl_board where bno > 0 

  ]]>


  <include refid="search"></include>

</select>


<sql id="search">

<if test="searchType != null" >

<!-- 

MyBatis에서는 변수가 자바객체처럼 사용되므로 

( OGNL (Object Graph Navigation Language)를 사용하여 속성 처리를 하고 있기 때문에 )

자바에서 사용되는 문자열 비교 메소드를 이용하면 된다.

단 비교할 문자를 먼저 쓴 경우도 에러 발생.


<if test="searchType == 't'.toString()"> (o)

<if test="searchType eq 't'.toString()"> (o)

<if test="searchType.toString() == 't'.toString()"> (o)

<if test="searchType.equalsIgnoreCase('t')"> (o)

<if test='searchType == "t"'> (o)


// 작은, 큰 따옴표 순서

<if test='"t".equals(searchType)'> (o)

<if test="'t'.equals(searchType)"> (x)


<if test='searchType.equals("t")'> (o)

<if test="searchType.equals('t')"> (x)

-->


<if test="searchType == 't'.toString()">

and title like CONCAT('%', #{keyword}, '%')

</if>

<if test="searchType == 'c'.toString()">

and content like CONCAT('%', #{keyword}, '%')

</if>

<if test="searchType == 'w'.toString()">

and writer like CONCAT('%', #{keyword}, '%')

</if>

<if test="searchType == 'tc'.toString()">

and ( title like CONCAT('%', #{keyword}, '%') OR content like CONCAT('%', #{keyword}, '%'))

</if>

<if test="searchType == 'cw'.toString()">

and ( content like CONCAT('%', #{keyword}, '%') OR writer like CONCAT('%', #{keyword}, '%'))

</if>

<if test="searchType == 'tcw'.toString()">

and 

( title like CONCAT('%', #{keyword}, '%') 

OR content like CONCAT('%', #{keyword}, '%') 

OR writer like CONCAT('%', #{keyword}, '%'))

</if>

</if>

</sql>


</mapper>




== 설명 ==

<if test>는 test 속성에 있는 표현식이 boolean으로 나오는 결과야 한다.

검색 조건들은 SQL의 like 구문으로 검색 되어야 하고, OR 조건이나 AND 조건에 들어가기 때문에 '()'를 이용해서 우선 순위를 부여한다.


id = listSearch , listSearchCount 둘다 동일하게 처리돼야 한다. 


MyBatis에는 <sql> 태그를 이용해서 동일한 SQL 구문을 재사용할 수 있는 방법을 제공한다.

재사용을 위해서 분리된 <sql>은 필요한 경우에 <include>를 이용해서 사용할 수 있다.


댓글목록

등록된 댓글이 없습니다.

회원로그인

회원가입

사이트 정보

공지사항
자유게시판
질문답변
1:1문의

 

별명 : 터푸가위
주소 : 부산시 동래구 명장로20번길 90
대표 : 박규태
메일 : dancepkt@******.com

접속자집계

오늘
270
어제
160
최대
10,760
전체
273,879
Copyright © dancePKT . All rights reserved.