DAO
전체 주문 개수 (검색 가능) - 사용자
public int getOrderCountByMem_num(
String keyfield,String keyword,int mem_num)
throws Exception{
Connection conn = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
String sql = null;
String sub_sql = "";
int count = 0;
try {
conn = DBUtil.getConnection();
if(keyword != null && !"".equals(keyword)) {
if(keyfield.equals("1")) sub_sql += "AND item_name LIKE '%' || ? || '%'";
else if(keyfield.equals("2")) sub_sql += "AND order_num=?";
}
sql = "SELECT COUNT(*) FROM zorder JOIN (SELECT order_num,"
+ "LISTAGG(item_name,',') WITHIN GROUP (ORDER BY item_name) "
+ "item_name FROM zorder_detail GROUP BY order_num) "
+ "USING (order_num) WHERE mem_num=? " + sub_sql;
pstmt = conn.prepareStatement(sql);
pstmt.setInt(1, mem_num);
if(keyword !=null && !"".equals(keyword)) {
pstmt.setString(2, keyword);
}
rs = pstmt.executeQuery();
if(rs.next()) {
count = rs.getInt(1);
}
}catch(Exception e) {
throw new Exception(e);
}finally {
DBUtil.executeClose(rs, pstmt, conn);
}
return count;
}
전체 주문 목록 (검색 가능) - 사용자
public List<OrderVO> getListOrderByMem_num(
int start,int end,
String keyfield,String keyword,int mem_num)
throws Exception{
Connection conn = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
List<OrderVO> list = null;
String sql = null;
String sub_sql = "";
int cnt = 0;
try {
conn = DBUtil.getConnection();
if(keyword != null && !"".equals(keyword)) {
if(keyfield.equals("1")) sub_sql += "AND item_name LIKE '%' || ? || '%'";
else if(keyfield.equals("2")) sub_sql += "AND order_num=?";
}
sql = "SELECT * FROM (SELECT a.*, rownum rnum FROM ("
+ "SELECT * FROM zorder JOIN (SELECT order_num,"
+ "LISTAGG(item_name,',') WITHIN GROUP (ORDER BY item_name) "
+ "item_name FROM zorder_detail GROUP BY order_num) "
+ "USING (order_num) WHERE mem_num=? " + sub_sql
+ " ORDER BY order_num DESC)a) "
+ "WHERE rnum>=? AND rnum<=?";
pstmt = conn.prepareStatement(sql);
pstmt.setInt(++cnt, mem_num);
if(keyword !=null && !"".equals(keyword)) {
pstmt.setString(++cnt, keyword);
}
pstmt.setInt(++cnt, start);
pstmt.setInt(++cnt, end);
rs = pstmt.executeQuery();
list = new ArrayList<OrderVO>();
while(rs.next()) {
OrderVO order = new OrderVO();
order.setOrder_num(rs.getInt("order_num"));
order.setOrder_total(rs.getInt("order_total"));
order.setItem_name(rs.getString("item_name"));
order.setStatus(rs.getInt("status"));
order.setReg_date(rs.getDate("reg_date"));
list.add(order);
}
}catch(Exception e) {
throw new Exception(e);
}finally {
DBUtil.executeClose(rs, pstmt, conn);
}
return list;
}
개별 상품 목록
public List<OrderDetailVO> getListOrderDetail(
int order_num)throws Exception{
Connection conn = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
List<OrderDetailVO> list = null;
String sql = null;
try {
conn = DBUtil.getConnection();
sql = "SELECT * FROM zorder_detail WHERE order_num=? "
+ "ORDER BY item_num DESC";
pstmt = conn.prepareStatement(sql);
pstmt.setInt(1, order_num);
rs = pstmt.executeQuery();
list = new ArrayList<OrderDetailVO>();
while(rs.next()) {
OrderDetailVO detail = new OrderDetailVO();
detail.setItem_num(rs.getInt("item_num"));
detail.setItem_name(rs.getString("item_name"));
detail.setItem_price(rs.getInt("item_price"));
detail.setItem_total(rs.getInt("item_total"));
detail.setOrder_quantity(rs.getInt("order_quantity"));
detail.setOrder_num(rs.getInt("order_num"));
list.add(detail);
}
}catch(Exception e) {
throw new Exception(e);
}finally {
DBUtil.executeClose(rs, pstmt, conn);
}
return list;
}
주문 상세
public OrderVO getOrder(int order_num)throws Exception{
Connection conn = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
OrderVO order = null;
String sql = null;
try {
conn = DBUtil.getConnection();
sql = "SELECT * FROM zorder WHERE order_num=?";
pstmt = conn.prepareStatement(sql);
pstmt.setInt(1, order_num);
rs = pstmt.executeQuery();
if(rs.next()) {
order = new OrderVO();
order.setOrder_num(rs.getInt("order_num"));
order.setOrder_total(rs.getInt("order_total"));
order.setPayment(rs.getInt("payment"));
order.setStatus(rs.getInt("status"));
order.setReceive_name(rs.getString("receive_name"));
order.setReceive_post(rs.getString("receive_post"));
order.setReceive_address1(rs.getString("receive_address1"));
order.setReceive_address2(rs.getString("receive_address2"));
order.setReceive_phone(rs.getString("receive_phone"));
order.setNotice(rs.getString("notice"));
order.setReg_date(rs.getDate("reg_date"));
order.setMem_num(rs.getInt("mem_num"));
}
}catch(Exception e) {
throw new Exception(e);
}finally {
DBUtil.executeClose(rs, pstmt, conn);
}
return order;
}
}
Action
User Order Detail
package kr.order.action;
import java.util.List;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import kr.controller.Action;
import kr.order.dao.OrderDAO;
import kr.order.vo.OrderDetailVO;
import kr.order.vo.OrderVO;
public class UserOrderDetailAction implements Action{
@Override
public String execute(HttpServletRequest request, HttpServletResponse response) throws Exception {
HttpSession session = request.getSession();
Integer user_num =
(Integer)session.getAttribute("user_num");
if(user_num==null) {
return "redirect:/member/loginForm.do";
}
int order_num = Integer.parseInt(
request.getParameter("order_num"));
OrderDAO dao = OrderDAO.getInstance();
OrderVO order = dao.getOrder(order_num);
if(order.getMem_num()!=user_num) {
return "/WEB-INF/views/common/notice.jsp";
}
List<OrderDetailVO> detailList =
dao.getListOrderDetail(order_num);
request.setAttribute("order", order);
request.setAttribute("detailList", detailList);
return "/WEB-INF/views/order/user_detail.jsp";
}
}
package kr.order.action;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import kr.controller.Action;
import kr.order.dao.OrderDAO;
import kr.order.vo.OrderVO;
public class UserModifyFormAction implements Action{
@Override
public String execute(HttpServletRequest request, HttpServletResponse response) throws Exception {
HttpSession session = request.getSession();
Integer user_num =
(Integer)session.getAttribute("user_num");
if(user_num==null) {
return "redirect:/member/loginForm.do";
}
int order_num = Integer.parseInt(
request.getParameter("order_num"));
OrderDAO dao = OrderDAO.getInstance();
OrderVO order = dao.getOrder(order_num);
if(order.getMem_num() != user_num) {
return "/WEB-INF/views/common/notice.jsp";
}
request.setAttribute("order", order);
return "/WEB-INF/views/order/user_modifyForm.jsp";
}
}
View
My Page - 추가
<div class="mypage-div">
<h3>관심 게시물 목록</h3>
<table>
<tr>
<th>제목</th>
<th>작성자</th>
<th>등록일</th>
</tr>
<c:forEach var="board" items="${boardList}">
<tr>
<td><a href="${pageContext.request.contextPath}/board/detail.do?board_num=${board.board_num}" target="_blank">${fn:substring(board.title,0,12)}</a></td>
<td>${board.id}</td>
<td>${board.reg_date}</td>
</tr>
</c:forEach>
</table>
<h3>상품구매목록 <input type="button" value="더보기" onclick="location.href='${pageContext.request.contextPath}/order/orderList.do'"></h3>
<table>
<tr>
<th>주문번호</th>
<th>상품명</th>
<th>주문날짜</th>
<th>배송상태</th>
</tr>
<c:forEach var="order" items="${orderList}">
<tr>
<td>${order.order_num}</td>
<td><a href="${pageContext.request.contextPath}/order/orderDetail.do?order_num=${order.order_num}">${order.item_name}</a></td>
<td>${order.reg_date}</td>
<td>
<c:if test="${order.status == 1}">배송대기</c:if>
<c:if test="${order.status == 2}">배송준비중</c:if>
<c:if test="${order.status == 3}">배송중</c:if>
<c:if test="${order.status == 4}">배송완료</c:if>
<c:if test="${order.status == 5}">주문취소</c:if>
</td>
</tr>
</c:forEach>
</table>
</div>
<div class="mypage-end"></div>
User Detail
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>구매상세</title>
<link rel="stylesheet" href="${pageContext.request.contextPath}/css/style.css" type="text/css">
</head>
<body>
<div class="page-main">
<jsp:include page="/WEB-INF/views/common/header.jsp"/>
<div class="content-main">
<h2>구매상세</h2>
<table>
<tr>
<th>상품명</th>
<th>수량</th>
<th>상품가격</th>
<th>합계</th>
</tr>
<c:forEach var="detail" items="${detailList}">
<tr>
<td>${detail.item_name}</td>
<td class="align-center">
<fmt:formatNumber value="${detail.order_quantity}"/>
</td>
<td class="align-center">
<fmt:formatNumber value="${detail.item_price}"/>원
</td>
<td class="align-center">
<fmt:formatNumber value="${detail.item_total}"/>원
</td>
</tr>
</c:forEach>
<tr>
<td colspan="3" class="align-right"><b>총구매금액</b></td>
<td class="align-center"><fmt:formatNumber value="${order.order_total}"/>원</td>
</tr>
</table>
<ul id="delivery_info">
<li>
<span>받는 사람</span> ${order.receive_name}
</li>
<li>
<span>우편번호</span> ${order.receive_post}
</li>
<li>
<span>주소</span> ${order.receive_address1} ${order.receive_address2}
</li>
<li>
<span>전화번호</span> ${order.receive_phone}
</li>
<li>
<span>남기실 말씀</span> ${order.notice}
</li>
<li>
<span>결제수단</span>
<c:if test="${order.payment == 1}">통장입금</c:if>
<c:if test="${order.payment == 2}">카드결제</c:if>
</li>
<li>
<span>배송상태</span>
<c:if test="${order.status == 1}">배송대기</c:if>
<c:if test="${order.status == 2}">배송준비중</c:if>
<c:if test="${order.status == 3}">배송중</c:if>
<c:if test="${order.status == 4}">배송완료</c:if>
<c:if test="${order.status == 5}">주문취소</c:if>
</li>
<li class="align-center">
<c:if test="${order.status == 1}">
<input type="button" value="배송지정보수정"
onclick="location.href='orderModifyForm.do?order_num=${order.order_num}'">
<input type="button" value="주문 취소" id="order_cancel">
<script>
const order_cancel = document.getElementById('order_cancel');
order_cancel.onclick=function(){
let choice = confirm('주문을 취소하시겠습니까?');
if(choice){
location.replace('orderCancel.do?order_num=${order.order_num}'); }
};
</script>
</c:if>
<input type="button" value="주문목록"
onclick="location.href='orderList.do'">
<input type="button" value="MY페이지"
onclick="location.href='${pageContext.request.contextPath}/member/myPage.do'">
</li>
</ul>
</div>
</div>
</body>
</html>
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>배송지정보 수정</title>
<link rel="stylesheet" href="${pageContext.request.contextPath}/css/style.css" type="text/css">
<script type="text/javascript" src="${pageContext.request.contextPath}/js/jquery-3.7.1.min.js"></script>
<script type="text/javascript">
window.onload=function(){
const myForm = document.getElementById('order_modify');
myForm.onsubmit = function(){
const items = document.querySelectorAll('input[type="text"]');
for(let i=0;i<items.length;i++){
if(items[i].value.trim()==''){
const label = document.querySelector(
'label[for="'+items[i].id+'"]');
alert(label.textContent + ' 항목은 필수 입력');
items[i].value = '';
items[i].focus();
return false;
}
if(items[i].id == 'zipcode'
&& !/^[0-9]{5}$/.test(items[i].value)){
alert('우편번호를 입력하세요(숫자5자리)');
items[i].value = '';
items[i].focus();
return false;
}
}
};
};
</script>
</head>
<body>
<div class="page-main">
<jsp:include page="/WEB-INF/views/common/header.jsp"/>
<div class="content-main">
<h2>배송지정보 수정</h2>
<c:if test="${order.status != 1}">
<div class="result-display">
배송대기일 때만 배송지정보를 수정할 수 있습니다.
</div>
</c:if>
<c:if test="${order.status == 1}">
<form action="orderModify.do" method="post" id="order_modify">
<ul>
<li>
<label for="receive_name">받는 사람</label>
<input type="text" name="receive_name"
value="${order.order_num}"
id="receive_name" maxlength="10">
</li>
<li>
<label for="zipcode">우편번호</label>
<input type="text" name="receive_post"
value="${order.receive_post}"
id="zipcode" maxlength="5">
<input type="button" onclick="execDaumPostcode()"
value="우편번호 찾기">
</li>
<li>
<label for="address1">주소</label>
<input type="text" name="receive_address1"
value="${order.receive_address1}"
id="address1" maxlength="30">
</li>
<li>
<label for="address2">상세주소</label>
<input type="text" name="receive_address2"
value="${order.receive_address2}"
id="address2" maxlength="30">
</li>
<li>
<label for="receive_phone">전화번호</label>
<input type="text" name="receive_phone"
value="${order.receive_phone}"
id="receive_phone" maxlength="15">
</li>
<li>
<label for="notice">남기실 말씀</label>
<textarea rows="5" cols="30" name="notice"
id="notice" maxlength="1300">${order.notice}</textarea>
</li>
</ul>
<div class="align-center">
<input type="submit" value="수정">
<input type="button" value="주문목록"
onclick="location.href='orderList.do'">
<input type="button" value="MY페이지"
onclick="location.href='${pageContext.request.contextPath}/member/myPage.do'">
</div>
</form>
<!-- 다음 우편번호 API 시작 -->
<!-- iOS에서는 position:fixed 버그가 있음, 적용하는 사이트에 맞게 position:absolute 등을 이용하여 top,left값 조정 필요 -->
<div id="layer" style="display:none;position:fixed;overflow:hidden;z-index:1;-webkit-overflow-scrolling:touch;">
<img src="//t1.daumcdn.net/postcode/resource/images/close.png" id="btnCloseLayer" style="cursor:pointer;position:absolute;right:-3px;top:-3px;z-index:1" onclick="closeDaumPostcode()" alt="닫기 버튼">
</div>
<script src="//t1.daumcdn.net/mapjsapi/bundle/postcode/prod/postcode.v2.js"></script>
<script>
var element_layer = document.getElementById('layer');
function closeDaumPostcode() {
element_layer.style.display = 'none';
}
function execDaumPostcode() {
new daum.Postcode({
oncomplete: function(data) {
var addr = '';
var extraAddr = '';
if (data.userSelectedType === 'R') {
addr = data.roadAddress;
} else {
addr = data.jibunAddress;
}
if(data.userSelectedType === 'R'){
if(data.bname !== '' && /[동|로|가]$/g.test(data.bname)){
extraAddr += data.bname;
}
if(data.buildingName !== '' && data.apartment === 'Y'){
extraAddr += (extraAddr !== '' ? ', ' + data.buildingName : data.buildingName);
}
if(extraAddr !== ''){
extraAddr = ' (' + extraAddr + ')';
}
}
document.getElementById('zipcode').value = data.zonecode;
document.getElementById("address1").value = addr + extraAddr;
document.getElementById("address2").focus();
element_layer.style.display = 'none';
},
width : '100%',
height : '100%',
maxSuggestItems : 5
}).embed(element_layer);
element_layer.style.display = 'block';
initLayerPosition();
}
function initLayerPosition(){
var width = 300;
var height = 400;
var borderWidth = 5;
element_layer.style.width = width + 'px';
element_layer.style.height = height + 'px';
element_layer.style.border = borderWidth + 'px solid';
element_layer.style.left = (((window.innerWidth || document.documentElement.clientWidth) - width)/2 - borderWidth) + 'px';
element_layer.style.top = (((window.innerHeight || document.documentElement.clientHeight) - height)/2 - borderWidth) + 'px';
}
</script>
<!-- 다음 우편번호 API 끝 -->
</c:if>
</div>
</div>
</body>
</html>
Properties
Shop
/order/orderDetail.do=kr.order.action.UserOrderDetailAction
/order/orderModifyForm.do=kr.order.action.UserModifyFormAction