[B -2-32] Ajax 댓글 처리 5
2019. 10. 6. 21:28ㆍProject B (SPMS)/Project B 파트5
반응형
댓글 수정
src/main/java
com.spms.mapper
ReplyMapper.java 인터페이스
update()
...더보기
package com.spms.mapper;
import com.spms.domain.ReplyVO;
public interface ReplyMapper {
public int insert(ReplyVO vo);
public ReplyVO read(Long bno);
public int delete(Long rno);
public int update(ReplyVO reply);
}
src/main/resources
com
spms
mapper
ReplyMapper.xml
update()
...더보기
<?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.spms.mapper.ReplyMapper">
<insert id="insert">
insert into TBL_REPLY (
RNO, BNO, REPLY, REPLYER
)
values (
SEQ_REPLY.NEXTVAL, #{bno}, #{reply}, #{replyer}
)
</insert>
<select id="read" resultType="com.spms.domain.ReplyVO">
select *
from TBL_REPLY
WHERE RNO = #{rno}
</select>
<delete id="delete">
delete from TBL_REPLY
where RNO = #{rno}
</delete>
<update id="update">
update TBL_REPLY
set REPLY = #{reply},
UPDATEDATE = SYSDATE
where RNO = #{rno}
</update>
</mapper>
src/test/java
com.spms.mapper
ReplyMapperTests.java
testUpdate()
...더보기
package com.spms.mapper;
import java.util.stream.IntStream;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import com.spms.domain.ReplyVO;
import lombok.Setter;
import lombok.extern.log4j.Log4j;
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(classes = {com.spms.config.RootConfig.class} )
@Log4j
public class ReplyMapperTests {
private Long[] bnoArr = { 524313L, 524312L, 524311L, 524310L, 524309L };
@Setter(onMethod_ = @Autowired)
private ReplyMapper replyMapper;
public void testMapper() {
log.info(replyMapper);
}
public void testCreate() {
IntStream.rangeClosed(1, 10).forEach(i -> {
ReplyVO replyVO = new ReplyVO();
replyVO.setBno(bnoArr[i % 5]);
replyVO.setReply("댓글 테스트! " + i);
replyVO.setReplyer("작성자" + i);
replyMapper.insert(replyVO);
});
}
public void testRead() {
Long targetRno = 5L;
ReplyVO replyVO = replyMapper.read(targetRno);
log.info(replyVO);
}
public void testDelete() {
Long targetRno = 7L;
replyMapper.delete(targetRno);
}
@Test
public void testUpdate() {
Long targetRno = 10L;
ReplyVO replyVo = replyMapper.read(targetRno);
replyVo.setReply("Update Reply");
int count = replyMapper.update(replyVo);
log.info("UPDATE COUNT : " + count);
}
}
수정할 댓글 번호(targetRno)를 지정한다.
댓글의 수정은 현재의 TBL_REPLY 테이블의 구조에서는 댓글의 내용과 최종 수정 시간을 수정한다.
댓글 수정 유닛 테스트
반응형
'Project B (SPMS) > Project B 파트5' 카테고리의 다른 글
[B -2-34] Ajax 댓글 처리 7 (0) | 2019.10.06 |
---|---|
[B -2-33] Ajax 댓글 처리 6 (0) | 2019.10.06 |
[B -2-31] Ajax 댓글 처리 4 (0) | 2019.10.06 |
[B -2-30] Ajax 댓글 처리 3 (0) | 2019.10.06 |
[B -2-29] Ajax 댓글 처리 2 (0) | 2019.10.06 |