관리 메뉴

nalaolla

parameterType HashMap 관련 예시(다중파라미터) 본문

MyBatis

parameterType HashMap 관련 예시(다중파라미터)

날아올라↗↗ 2016. 3. 27. 23:40
728x90

1. 기존 parameterType="String" 파라미터 한개로 처리


UserInfoMapper.java

1public interface UserInfoMapper {
2    public UserInfo getUserInfo(String userId);
3}


UserInfoMapper.xml

01<select id="getUserInfo" parametertype="String" resultmap="UserInfoResultMap">
02SELECT
03    id,
04    user_id,
05    state
06FROM
07    UserInfo
08WHERE
09    user_id = #{userId}
10</select>


UserInfoService.java

1String userId = "user_id_value";
2userInfo = userInfoMapper.getUserInfo(userId);

※ 단일 parameterType 로 String userId값 넣음


2.  parameterType HashMap을 이용해서 여러개 넣기


UserInfoMapper.java

1public interface UserInfoMapper {
2    public UserInfo getUserInfo(HashMap<String, Object> map);
3}

UserInfoMapper.xml

01<select id="getUserInfo" parametertype="hashmap" resultmap="UserInfoResultMap">
02SELECT
03    id,
04    user_id,
05    state
06FROM
07    UserInfo
08WHERE
09    user_id = #{userId}
10AND
11    state = #{state}
12</select>

UserInfoService.java

1HashMap<String, Object> map = new HashMap<String, Object>();
2map.put("userId""user_id_value");
3map.put("state""state_value");
4userInfo = userInfoMapper.getUserInfo(map);


3. 2번과 비슷하지만 기존 userInfo 도메인 이용


UserInfoMapper.java

1public interface UserInfoMapper {
2    public UserInfo getUserInfo(HashMap<String, Object> map);
3}

UserInfoMapper.xml

01<select id="getUserInfo" parametertype="hashmap" resultmap="UserInfoResultMap">
02SELECT
03    id,
04    user_id,
05    state
06FROM
07    UserInfo
08WHERE
09    user_id = #{user.userId}
10AND
11    state = #{user.state}
12</select>

UserInfoService.java

1UserInfo userInfo = new UserInfo();
2userInfo.setUserId("user_id_value");
3userInfo.setState("state_value");
4 
5HashMap<String, Object> map = new HashMap<String, Object>();
6map.put("user", userInfo);
7 
8userInfo = userInfoMapper.getUserInfo(map);

4. Param 이용


UserInfoMapper.java

1public interface UserInfoMapper {
2    public UserInfo getUserInfo(@Param("userId") String userId, @Param("state"int state);
3}

UserInfoMapper.xml

01<select id="getUserInfo" resultmap="UserInfoResultMap">
02SELECT
03    id,
04    user_id,
05    state
06FROM
07    UserInfo
08WHERE
09    user_id = #{userId}
10AND
11    state = #{state}
12</select>

UserInfoService.java

1String userid ="user_id_value";
2int state = 0;
3userInfo = userInfoMapper.getUserInfo(String userid,int state);


728x90