购物车中我的订单查询

1.分析:我的订单的查询主要是从数据库表中的订单表orders中查询出Orderitem中所战士的商品信息

其终极目标是封装Order对象,然后存到域中转发给jsp页面取值

首先要分清楚的问题是:

         * 一个订单集合下(List)有多个Order对象
         * 一个Order对象下有多个OrderItem订单项

         * 一个OrderItem对应一个Product对象

而要封装Order对象则必须从数据库中查出orderitem和product中的部分信息以封装Order表中的orderiten

购物车中我的订单查询_第1张图片

2.servlet页面代码

//我的订单查询
    public void orderList(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        
        HttpSession session = request.getSession();
        User user = (User) session.getAttribute("user");
        if(user==null) {
            response.sendRedirect(request.getContextPath()+"/login.jsp");
        }
        String uid = user.getUid();
        ProductService service = new ProductService();
        //查询该用户所有的订单集合   orders数据库中没有Orderitem这一项  所以要从数据库中查询  然后封装到orders中
        /**
         * 终极目标是封装Order对象
         *
         * 一个订单集合下(List)有多个Order对象
         * 一个Order对象下有多个OrderItem订单项
         * 一个OrderItem对应一个Product对象
         */
        List orderList = service.findOrderList(uid);
        //循环所有订单,为每个订单填充订单项集合信息
        if (orderList!=null) {
            for (Order order : orderList) {
                //获得每一个订单的oid---->用于查询每个订单下的所有orderItem项
                String oid = order.getOid();
                //查询该订单下的所有订单项
                List> mapList = service.findAllOrderItem(oid);
                for (Map map : mapList) {
                    try {
                        //封装OrderItem对象
                        OrderItem orderitem = new OrderItem();
                        BeanUtils.populate(orderitem, map);
                        
                        //封装Product对象
                        Product product = new Product();
                        BeanUtils.populate(product, map);
                        
                        //将product对象封装到ordritem中
                        orderitem.setProduct(product);
                        
                        //将orderitem对象封装到Order对象中
                        order.getOrderitem().add(orderitem);
                        
                    } catch (IllegalAccessException | InvocationTargetException e) {
                        e.printStackTrace();
                    }
                }
            }
        }
        //存域
        request.setAttribute("orderList", orderList);
        
        //转发
        request.getRequestDispatcher("/order_list.jsp").forward(request, response);

    }

3.service层页面代码

//查询当前用户下所有的订单集合
        public List findOrderList(String uid) {
            ProductDao dao = new ProductDao();
            List orderList = null;
            try {
                orderList = dao.findOrderList(uid);
            } catch (SQLException e) {
                e.printStackTrace();
            }
            return orderList;
        }

        //查询该订单下的所有订单项
        public List> findAllOrderItem(String oid) {
            ProductDao dao = new ProductDao();
            List> orderitem = null;
            try {
                orderitem = dao.findAllOrderItem(oid);
            } catch (SQLException e) {
                e.printStackTrace();
            }
            return orderitem;

        }

4.dao层页面代码

//查询当前用户下所有的订单集合
    public List findOrderList(String uid) throws SQLException {
        QueryRunner qr = new QueryRunner(DataSourceUtils.getDataSource());
        String sql = "select * from orders where uid=?";
        List query = qr.query(sql, new BeanListHandler(Order.class), uid);
        return query;
    }

    //查询该订单下的所有订单项
    public List> findAllOrderItem(String oid) throws SQLException {
        QueryRunner qr = new QueryRunner(DataSourceUtils.getDataSource());
        String sql = "select p.pimage,p.pname,p.shop_price,i.count,i.subtotal from product p,orderitem i where p.pid=i.pid and i.oid=?";
        List> query = qr.query(sql, new MapListHandler(), oid);
        return query;

    }

5.jsp页面主要代码


                    
                        
                            订单编号:${order.oid }
                        
                        
                            图片
                            商品
                            价格
                            数量
                            小计
                        
                        
                            
                                                                    value="22">                                     height="60">
                                 ${items.product.pname }
                                ¥${items.product.shop_price }
                                ${items.count }
                                ¥${items.subtotal }
                            
                        

                    
                


你可能感兴趣的:(JavaWeb,网上商城项目总结)