Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- reactor
- NoSQL
- github
- Elk
- libuv
- reactive
- Lombok
- javascript
- network
- html
- socket
- effective
- nodejs
- VCS
- 데이터통신
- Java
- 네트워크
- git
- ajax
- cache
- Heap
- redis
- Static
- mybatis
- AWS
- mongodb
- Linux
- spring
- HTTP
- r
Archives
- Today
- Total
빨간색코딩
Mapper XML (엘리먼트, CDATA) 본문
1. 엘리먼트
<mapper>
: 루트 엘리먼트- namespace : 유일한 id 만드는데 도움을 준다. ex. 네임스페이스.id
<select>
: select 구문에 사용- id : 필수속성, 유일한 id를 써야함
- parameterType : 인자 타입, 보통 패키지까지 안쓰고
<typeAlias>
로 간결하게 씀. - resultType : 필수속성, select의 결과로 반환된 resultSet이 매핑될 객체의 타입
<insert>
: insert 구문에 사용- id
- parameterType
<selectKey>
- keyProperty
- resultType
<update>
: update 구문에 사용- id
- parameterType
<delete>
: delete 구문에 사용- id
- parameter
<resultMap>
: select문에서 resultType 대신 resultMap 을 사용 가능하다. 검색 쿼리가 단순 테이블 조회가 아닌 join 구문을 포함할 때는 하나의 자바객체로 매핑할 수 없다. 이럴 때 resultMap 을 이용한다.
2. CDATA
xml 특성상 sql 구문 내 <
같은 걸 이용할 수 없다. <![CDATA[ 여기에 문자열을 쓰면 됌 ]]>
이렇게 하면 XML 파서가 PCDATA로 인식하지 않는다.
3. 보통 대문자를 쓴다
SQL 구문은 대소문자를 구분하지 않지만, SQL문은 대문자로 칼럼명과 파라미터들은 소문자로 표현하여 가독성을 높인다.
4. 예제
mybatis-config.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<properties resource="db.properties" />
<!-- Alias 설정 -->
<typeAliases>
<typeAlias alias="board" type="com.devljh.domain.board.BoardVO" />
</typeAliases>
<!-- DataSource 설정 -->
<environments default="development">
<environment id="development">
<transactionManager type="JDBC" />
<dataSource type="POOLED">
<property name="driver" value="${jdbc.driverClassName}" />
<property name="url" value="${jdbc.url}" />
<property name="username" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
</dataSource>
</environment>
</environments>
<!-- SQL Mapper 설정 -->
<mappers>
<mapper resource="mapper/boardMapper.xml" />
</mappers>
</configuration>
boardMapper.xml (MySQL 기준)
<?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="BoardDAO">
<resultMap id="boardResult" type="board">
<id property="seq" column="SEQ" />
<result property="title" column="TITLE" />
<result property="writer" column="WRITER" />
<result property="content" column="CONTENT" />
<result property="regDate" column="REGDATE" />
<result property="cnt" column="CNT" />
</resultMap>
<insert id="insertBoard">
INSERT INTO board(title, writer, content, regDate)
VALUES(#{title},#{writer},#{content},now())
</insert>
<update id="updateBoard">
UPDATE board SET title=#{title}, content=#{content}
WHERE seq=#{seq}
</update>
<delete id="deleteBoard">
DELETE FROM board WHERE seq=#{seq}
</delete>
<select id="getBoard" resultType="board">
SELECT * FROM board WHERE
seq=#{seq}
</select>
<select id="getBoardList" resultType="board">
SELECT * FROM board WHERE
title LIKE CONCAT('%',#{searchKeyword},'%') ORDER BY seq DESC
</select>
</mapper>
'Spring' 카테고리의 다른 글
freemarker (개념, jsp와 차이, 문법, spring과 연동 설정, 예제) (2) | 2018.01.09 |
---|---|
Mybatis와 spring 연동 (SqlSessionDaoSupport, SqlSessionTemplate) (1) | 2018.01.05 |
EHCache (ehcache-spring-annotations, ehcache.xml, @Cacheable) (0) | 2018.01.05 |
mybatis Framework (마이바티스 개념, ibatis와 차이, 구조, api, SqlSession) (1) | 2018.01.03 |
스프링프레임워크로 카카오 챗봇 만들기 (6) | 2017.05.11 |
Comments