Goods:查询某个用户的购物车条目以及添加购物车条目

 

CartItemDao

 1 //查询某个用户的某本图书的购物车条目是否存在
 2     public CartItem findByUidAndBid(String uid,String bid) throws SQLException
 3     {
 4         String sql="select * from t_cartitem where uid=? and bid=?";
 5         Map<String,Object> map=qr.query(sql, new MapHandler(),uid,bid);
 6         CartItem cartItem=toCartItem(map);
 7         return cartItem;
 8     }
 9     
10     //修改数量
11     
12     public void updateQuantity(String cartItemId,int quantity) throws SQLException
13     {
14         String sql="update t_cartitem set quantity=? where cartItemId=?";
15         qr.update(sql,quantity,cartItemId);
16     }
17     
18     //添加cartItem
19     
20     public void addCartItem(CartItem cartItem) throws SQLException
21     {
22         String sql="insert into t_cartitem(cartitemId,quantity,bid,uid)"+
23       " values(?,?,?,?)";
24         Object[] params={cartItem.getCartItemId(),cartItem.getQuantity(),
25                 cartItem.getBook().getBid(),
26                 cartItem.getUser().getUid()};
27         qr.update(sql,params);
28         
29         
30     }
31     //把一个map映射成一个cartItem
32     private CartItem toCartItem(Map<String,Object> map)
33     {   
34         //
35         if(map==null||map.size()==0) return null;
36         //1、把Map 
37         CartItem cartItem=CommonUtils.toBean(map, CartItem.class);
38         Book book=CommonUtils.toBean(map, Book.class);
39         User user=CommonUtils.toBean(map, User.class);
40         cartItem.setBook(book);
41         cartItem.setUser(user);
42         return cartItem;
43         
44     }
45     
46     //把多个map (List<Map>)映射成多个CartItem(List<CartItem>)
47     
48     private List<CartItem> toCartItemList(List<Map<String,Object>> mapList)
49     {
50         List<CartItem> cartItemList=new ArrayList<CartItem>();
51         for(Map<String,Object> map:mapList)
52         {
53             CartItem cartItem=toCartItem(map);
54             cartItemList.add(cartItem);
55         }
56         return cartItemList;
57     }
58     
59     //通过用户查询购物车条目
60     public List<CartItem> findByUser(String uid) throws SQLException
61     {   
62         //多表查询
63         String sql="select * from t_cartitem c,t_book b where c.bid=b.bid where uid=? order by c.orderBy";
64         List<Map<String, Object>> mapList=qr.query(sql, new MapListHandler(),uid);
65         
66         return toCartItemList(mapList);
67         
68     }

CartItemService

 1 public List<CartItem> myCart(String uid)
 2     {
 3         try {
 4             return cartItemDao.findByUser(uid);
 5         } catch (SQLException e) {
 6             // TODO Auto-generated catch block
 7             throw new RuntimeException(e);
 8         }
 9         
10     }
11     
12     //添加条目
13     public void add(CartItem cartItem)
14     {
15         //使用uid bid 看条目是否存在  _cartItem 加上下划线表示从数据库传过来的数据
16         try {
17             CartItem _cartItem=cartItemDao.findByUidAndBid
18                     (cartItem.getUser().getUid(), cartItem.getBook().getBid());
19             if(_cartItem==null) //如果没有原来这个条目 添加条目
20             {   
21                 cartItem.setCartItemId(CommonUtils.uuid());
22                 cartItemDao.addCartItem(cartItem);
23             }
24             else{ 
25                 //如果原来有这个条目 修改数量
26                 int quantity=cartItem.getQuantity()+_cartItem.getQuantity();
27                 //_cartItem.setQuantity(quantity);
28                 //修改老条目
29                 cartItemDao.updateQuantity(_cartItem.getCartItemId(), quantity);
30         
31             }
32         } catch (SQLException e) {
33             throw new RuntimeException(e);
34         }
35     }

 效果图如下:

posted @ 2015-09-06 12:06  尾巴草  阅读(393)  评论(0编辑  收藏  举报