[B -2-32] Ajax 댓글 처리 5

2019. 10. 6. 21:28Project 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