Notice
Recent Posts
Recent Comments
Link
| 일 | 월 | 화 | 수 | 목 | 금 | 토 |
|---|---|---|---|---|---|---|
| 1 | 2 | 3 | ||||
| 4 | 5 | 6 | 7 | 8 | 9 | 10 |
| 11 | 12 | 13 | 14 | 15 | 16 | 17 |
| 18 | 19 | 20 | 21 | 22 | 23 | 24 |
| 25 | 26 | 27 | 28 | 29 | 30 | 31 |
Tags
- after-throwing
- spring
- produces
- @Valid
- 의존주입
- springjdbc
- @ResponseBody
- 생성자주입
- 서비스레이어
- 스프링
- application.properties
- @
- MVC
- 어노테이션
- gradle
- c:if
- Java
- jointpoint
- 바인딩변수
- SpringBoot
- AOP
- Model
- @RequestParam
- 유효성검사
- frontController
- 비즈니스레이어
- @RequestMapping
- springmvc
- .xml
- PointCut
Archives
- Today
- Total
메모장
JDBC - 임시 멤버 변수 구현 본문
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 |