MyBatis findById에서 id null
456
작성자 없음
작성한 질문수 0
현재 mysql과 연동해서 테스트를 진행하였고
ItemMapper.xml상에 코드는 다음과 같습니다
<?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="InflearnSpringDBReal.SpringDB3MyBatis.repository.mybatis.ItemMapper">
<insert id="save" useGeneratedKeys="true" keyProperty="id" keyColumn="item_id">
INSERT INTO Item (item_name, price, quantity)
VALUES (#{itemName}, #{price}, #{quantity})
</insert>
<update id="update">
UPDATE Item
SET item_name=#{updateParam.itemName},
price=#{updateParam.price},
quantity=#{updateParam.quantity}
WHERE item_id=#{item_id}
</update>
<select id="findById" resultType="Item">
SELECT item_id, item_name, price, quantity
FROM Item
WHERE item_id=#{id}
</select>
<select id="findAll" resultType="Item">
SELECT item_id, item_name, price, quantity
FROM Item
<where>
<if test="itemName != null and itemName != ''">
AND item_name LIKE concat('%',#{itemName},'%')
</if>
<if test="maxPrice != null">
AND price <=#{maxPrice}
</if>
</where>
</select>
</mapper>
item table은 다음과 같습니다
![]()
@Test
void save() {
// given
Item item = new Item("itemA", 10000, 10);
log.info("item = {}", item);
// when
Item savedItem = itemRepository.save(item);
log.info("savedItem = {}", savedItem);
log.info("saveItem.getId() = {}", savedItem.getId());
log.info("{}", itemRepository.findById(savedItem.getId()));
// then
Item findItem = itemRepository.findById(savedItem.getId()).orElse(null);
log.info("findItem = {}", findItem);
assertThat(findItem).isEqualTo(savedItem);
}
이 테스트를 진행하게되면 결과가 다음과 같이 나오는데

여기서 왜 findItem에 id가 null로 나오는지 파악이 안되고 이거때문에 save test가 failed이 나옵니다. 어디가 문제인지 알수있나요??
답변 1
RepositoryTest의 패키지 위치가 domain인 이유
0
29
2
REQUIRES_NEW 해결 방법에 대해서 질문있습니다!!
0
29
1
update()에 사용하는 setter 질문드립니다.
0
47
1
SQL 중심적 개발의 문제점에 대한 질문
0
72
1
혹시 Containing 을 안쓰신 이유가 있을까요?
0
83
2
[공유] 스프링부트 4.x 버전 mybatis 연동
0
173
1
@repository 어노테이션
0
89
3
ItemService
0
58
1
논리 커밋, 물리 커밋 질문드립니다.
0
54
1
내부 트랜잭션 커밋은 필수인가요?
0
57
1
프록시 커넥션 객체를 반환할 때 생성하는건가요?
0
54
1
Transaction readOnly 성능 개선 (김영한님의 대한 감사인사)
2
178
2
JPQL 대신 네이티브 쿼리를 사용해야 하는 경우
0
77
1
@EventListener(ApplicationReadyEvent.class) 관련
0
88
1
트랜잭션 동기화 매니저와 데이터 소스
0
76
1
DB 관련 강의 개설 계획은 없으신건가요?
0
133
2
물리 트랜잭션 과 논리트랜잭션 용어를 맞게 이해한걸까요
0
94
1
스프링 3 버전 이상 rollbackFor 변경된듯요
1
112
1
트랜잭션 전파 질문.
0
87
1
프로젝트 오픈 에러
0
126
1
외부 트랜잭션에서 isNewTransaction이 false로 나오는거에 대해 질문드립니다
0
83
2
같은 스레드를 사용하면 트랜잭션 동기화 매니저는 같은 커넥션을 반환
0
72
1
h2 인메모리 테스트중 예약어 충돌날 경우 대처방법
0
102
1
커스텀aop와 트랜잭션을 같이 사용할때 우선순위에 관한 질문
0
98
2





