Spring
Spring mybatis를 통해 객체 안에있는 객체에 값 넣기
pooney
2020. 5. 7. 03:14
객체 안에 있는 콜렉션이나 객체에 값을 넣어야하는 경우가 발생한다 이때 mybatis의 collection 태그를 이용하여 해결 할 수 있다.
collection 태그
controller
@Controller
public class HomeController {
@Inject
SqlSession sqlSession;
@RequestMapping(value = "addlist", method = RequestMethod.GET)
public String addlist() {
System.out.println("addlist");
List<TestClass> list = sqlSession.selectList("list.selectlist");
System.out.println(list);
return "index";
}
}
TestClass
@Data
public class TestClass {
private String id;
private String pwd;
private List<String> namelist;
}
DB테이블
test1 테이블
test2 테이블
mapper.xml
collection 태그의 column은 selectlist에서 조회된 id 값을 파라미터 selectnamelist에게 넘겨 조회 하게 된다.
또한 select 속성은 또 다른 select를 나누어 실행 가능하게 할 수 있다.
<mapper namespace="list">
<resultMap type="com.ex.test.TestClass" id="ResultMap">
<id property="id" column="id" />
<id property="pwd" column="pwd" />
<collection property="namelist" column="id" select="selectnamelist"/>
</resultMap>
<select id="selectnamelist" resultType="string">
select name from test2 where id = #{id}
</select>
<select id="selectlist" resultMap="ResultMap">
select * from test1
</select>
</mapper>
addlist 요청 화면
결과
TestClass에 멤버변수 namelist에 정상적으로 값이 들어가 간것을 확인 할 수 있다.