메모장

JDBC - 임시 멤버 변수 구현 본문

DB/개념정리

JDBC - 임시 멤버 변수 구현

Itchild 2024. 4. 10. 22:26
728x90
반응형

Model - MemberVO

package model;

public class MemberVO {
	private String mid;
	private String mpw;
	private int total; //이거는 그냥 총 금액
	private int tmpPrice; // DB_테이블에는 없지만 개발 편의성 때문에 JAVA_VO에서 구현한 멤버 변수
	// 오늘의 핵심 ★★★★★
    // 얘는 총금액을 < 얼마만큼 > 올려줘 // 얼마 만큼이 없어서 임시로 변수를 하나 만듬
	// 얘는 임시라서 생성자를 만들 필요 없다 !
	// private는 붙어서 getter,setter는 써줘야 함 
	private int tmpNum;
	
	public int getTmpNum() {
		return tmpNum;
	}
	public void setTmpNum(int tmpNum) {
		this.tmpNum = tmpNum;
	}
	public int getTmpPrice() {
		return tmpPrice;
	}
	public void setTmpPrice(int tmpPrice) {
		this.tmpPrice = tmpPrice;
	}
	public MemberVO(String mid,String mpw) {
		this(mid,mpw,0);
	}
	public MemberVO(String mid,String mpw,int total) {
		this.mid=mid;
		this.mpw=mpw;
		this.total=total;
	}
	public String getMid() {
		return mid;
	}
	public void setMid(String mid) {
		this.mid = mid;
	}
	public String getMpw() {
		return mpw;
	}
	public void setMpw(String mpw) {
		this.mpw = mpw;
	}
	public int getTotal() {
		return total;
	}
	public void setTotal(int total) {
		this.total = total;
	}
	@Override
	public String toString() {
		return mid+" 회원 비번 ["+mpw+"] 총 구매금액 ["+total+"]";
	}
}
 

Controller

// 임시 멤버변수를 사용한 구매하기 실행 코드를 가져왔다
   else if(action==3) { // 구매하기 
				int proNum=view.getNum(); // v가 상품뭐 구매했는지 입력을 받아옴
				ProductVO pVO=new ProductVO(proNum,null,0,0);
				ProductVO pdata=pDAO.selectOne(pVO);
                // 상품 구매가능 여부 확인
				if(pdata==null) { //1. 없는 상품인지
					System.out.println(" 로그: 해당상품없음");
					view.printFalse();
					continue;
				}
				if(pdata.getCnt()<=0) { //2. 재고있는지
					System.out.println(" 로그: 상품재고없음");
					view.printFalse();
					continue;
				}

                // 구매가 가능하다면 
				// 구매를 진행
				//구매를 하면 재고 -- 로 한 개 줄어야 하고
				// 사용자 총 금액 total ++ 은 늘어야 한다.

				if(!pDAO.update(pdata)) { // 재고 -- 이슈로 실행되지 않았을때
					System.out.println(" 로그: P update()안됨");
					view.printFalse();
					continue;
				}
				member.setTmpPrice(pdata.getPrice()); // 사용자 총 금액을 늘려줘  
                // 오늘의 핵심 ★★★★★
                // 회원의 상품 총 금액을 !!얼마만큼(=임시변수setTmpPrice)!! 올려줘 
				// 개발 편의성때문에 새로 만든 VO의 멤버변수를 활용한 로직
				

				if(!mDAO.update(member)) { // 회원의 총 금액 이슈로 실행이 안되었을 때 
					System.out.println(" 로그: M update()안됨");
					view.printFalse();
					continue;
				}
				view.printTrue(); // 여기 까지 내려왔다면 구매 성공 !
				
			}
 

 

 

728x90
반응형

'DB > 개념정리' 카테고리의 다른 글

JOIN 과 순위함수  (0) 2024.04.10
데이터 그룹화 GROUP BY,HAVING,그룹함수  (0) 2024.04.10
JDBC PrepareStatement  (0) 2024.04.10
MySQL 날짜 , 날짜함수  (0) 2024.04.10
JDBC - MVC패턴으로 만들기(웹크롤링)  (0) 2024.04.10