사용자 요청 list.jsp 에서 해당 계좌 번호 선택 - (list.jsp 링크 수정 해야 함)
1. detail.jsp 만들기
2. account/list.jsp 파일에 링크 추가 하기
3. 계좌 상세 보기 기능 구현
2. AccountController 주소 설계 및 코드 추가
3. 거래 내역 쿼리 확인 후 DTO 설계 - HistoryDTO
4. AccountService 상세 보기 기능 구현 단일 계좌 검색 기능 추가 거래 내역 확인 기능 추가 (동적 쿼리 생성)
5. utils/TimestampUtil 클래스 추가 - 시간 포맷 기능
6. #,### 금액 단위 포맷 기능 추가 - HistoryDto 클래스에 기능 추가
코드상에서 사용할 쿼리 다시 확인
-- 코드상에서 사용할 쿼리 생성
-- 출금에 대한 쿼리 출력
-- receiver : 금액을 받는 대상,
-- 기능적으로 하나의 JSP 페이지에서 전체 쿼리에 대한 결과 집합에
-- 컬럼명을 동일하게 사용할 수 있도록 쿼리를 수정합니다 (같은 모델 클래스에 담을 예정)
-- 출금에는 AMT 출금, 1111 ---> 2222 이체
select h.id, h.amount, h.w_balance AS balance, h.created_at,
coalesce(cast(da.number as CHAR(10)), 'ATM') as receiver,
wa.number as sender
from history_tb as h
left join account_tb as wa on wa.id = h.w_account_id
left join account_tb as da on da.id = h.d_account_id
where h.w_account_id = 1;
-- 입금에 대한 쿼리 출력 ( AMT 입금, 다른계좌에서 --> 1111계 받거나)
select h.id, h.amount, h.d_balance as balance, h.created_at,
coalesce(CAST(wa.number as CHAR(10)) , 'ATM') as sender,
da.number as receiver
from history_tb as h
left join account_tb as wa on wa.id = h.w_account_id
left join account_tb as da on da.id = h.d_account_id
where h.d_account_id = 1;
-- 입,출금 전체 쿼리
select h.id, h.amount,
case
when h.w_account_id = 1 then (h.w_balance)
when h.d_account_id = 1 then (h.d_balance)
end as balance,
coalesce(cast(wa.number as char(10)), 'ATM') as sender,
coalesce(cast(da.number as char(10)), 'ATM') as receiver,
h.created_at
from history_tb as h
left join account_tb as wa on h.w_account_id = wa.id
left join account_tb as da on h.d_account_id = da.id
where h.w_account_id = 1 OR h.d_account_id = 1;
select * from history_tb
728x90
'Spring boot > Bank App 만들기(deployment)' 카테고리의 다른 글
Bank App 만들기 ( deployment ) - 계좌 상세보기 페이징 처리 (0) | 2024.08.12 |
---|---|
Bank App 만들기 ( deployment ) - 간단한 유틸 클래스 만들어 보기 (1) | 2024.08.12 |
Bank App 만들기 ( deployment ) - 계좌 상세보기 1단계 ( 쿼리 학습 ) (0) | 2024.08.09 |
Bank App 만들기 ( deployment ) - 이체 기능 만들기 (1) | 2024.08.08 |
Bank App 만들기 ( deployment ) - 입금 기능 만들기 (0) | 2024.08.08 |