Jsp电子商务之七 订单篇2
从View页面,点击超链接查询订单,进入到控制器
OrderlistServlet
package com.cart.web;
import java.io.IOException;
import java.util.*;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import com.cart.entity.*;
import com.cart.service.OrderService;
public class OrderlistServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
//从View来获取查询订单;
OrderService orderService=new OrderService();
Map<Order,ArrayList<Book>> map=(Map<Order,ArrayList<Book>>)orderService.getOrders(null, null);
HttpSession session=req.getSession();
session.setAttribute("map",map); //将订单map存放到session中;
//Iterator it=map.entrySet().iterator();
//System.out.println(map.entrySet().size());//长度为2是对的;
//下面如何获取订单对象和对应的图书详情信息呢;
//后台测试代码
// Order key;
// ArrayList<Book> value;
// while(it.hasNext()){
// Map.Entry<Order,ArrayList<Book>>entry=(Map.Entry<Order,ArrayList<Book>>)it.next();
// key=entry.getKey();
// value=entry.getValue();
//
// System.out.println("订单"+key.getId());
// System.out.println("书名\t\t价格\t数量\t总价");
// for(Book book:value){
// System.out.println(book.getBookname()+"/"+book.getImage()+"/"+book.getPrice()+"/"+book.getCount()+"/"+key.getTotal());
// }
// System.out.println();
// }
resp.sendRedirect("orderlist.jsp");
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
this.doGet(req, resp);
}
}
OrderService
package com.cart.service;
import java.sql.*;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;
import com.cart.dao.*;
import com.cart.dao.impl.*;
import com.cart.entity.Book;
import com.cart.entity.Order;
import com.cart.entity.Userinfo;
import com.cart.util.DaoFactory;
import com.cart.util.PageControler;
public class OrderService {
//1.定义属性:对dao进行操作;
OrderDao orderDao=new OrderDaoImpl();
CartDao cartDao=new CartDaoImpl();
//2.对订单,进行增删该查
public void delCartAndSaveOrder(String sbid,Userinfo user,Order order){
//使用事务操作,业务层可以这样操作,对不同的dao操作;
Connection con=null;
PreparedStatement pstmt=null;
try{
StringBuilder sbSql=new StringBuilder();
sbSql.append("delete from cartitem where uid=? and bid in(");
sbSql.append(sbid);
sbSql.append(")");
String sql=sbSql.toString();
con=DaoFactory.getConnection();
pstmt=con.prepareStatement(sql);
con.setAutoCommit(false);//设置自动提交事务,为false
orderDao.insertOrder(order);//调用杀入订单方法;,同时删除原来的购物车数据方法;
Object[] params={user.getId()};
DaoFactory.setParams(pstmt, params);
DaoFactory.executeUpdate(sql, params);
System.out.println(sbSql);
con.commit();
}catch(Exception e){
e.printStackTrace();
}finally{
DaoFactory.closeAll(null, pstmt, con);
}
}
public int insertOrder(Order order){
//ct.deletecartItem(uid, bid);
return orderDao.insertOrder(order);
}
public int updateOrder(int id){
return orderDao.updateOrder(id);
}
public int deleteOrder(int id){
return orderDao.deleteOrder(id);
}
public Order findOrderById(int id){
return orderDao.findOrderById(id);
}
public Map <Order,ArrayList<Book>> getOrders(String sql, PageControler pager) {//获取多条订单并带有详情
Connection con = null;
Map <Order,ArrayList<Book>> rtn = new HashMap <Order,ArrayList<Book>>();
try {
con = DaoFactory.getConnection();
OrderDao orderDao = new OrderDaoImpl();
rtn = orderDao.getOrders(sql, pager);
} catch (SQLException e) {
e.printStackTrace();
} finally {
DaoFactory.closeAll(null, null, con);
}
return rtn;
}
}
OrderDao的实现类
package com.cart.dao.impl;
import java.sql.*;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import com.cart.dao.OrderDao;
import com.cart.entity.Book;
import com.cart.entity.Order;
import com.cart.util.DaoFactory;
import com.cart.util.PageControler;
public class OrderDaoImpl implements OrderDao{
PreparedStatement pstmt=null;
Connection con=null;
public int deleteOrder(int id) {
return 0;
}
public Order findOrderById(int id) {
return null;
}
public int insertOrder(Order order) {
//将你所获得的订单数据,插入到数据库;
int result=-1;
try {
String sql="insert orders(userid,createtime,total,address,phone,status)values(?,?,?,?,?,?)";
con=DaoFactory.getConnection();
pstmt=con.prepareStatement(sql);
Object[] params={order.getUserid(),order.getCreatetime(),order.getTotal(),order.getShipaddress(),order.getContactphone(),order.getStatus()};
DaoFactory.setParams(pstmt, params);
result=pstmt.executeUpdate();
} catch (SQLException e) {
e.printStackTrace();
}finally{
DaoFactory.closeAll(null, pstmt, con);
}
return result;
}
public int updateOrder(int id) {
return 0;
}
、、//参数用于以后代码扩展
public Map<Order, ArrayList<Book>> getOrders(String sqlCon,
PageControler pager) throws SQLException {
List<Order> rtn = new ArrayList<Order>(); //可能会存在1个客户有多个订单,对吧;
//String sql="select O.*,OD.* from orders O inner join orderdetails OD on O.id=OD.oid";
String sql="select O.id,o.createtime,o.total,od.count,od.transprice,b.bookname,b.price,b.image" +
" from orders o inner join orderdetails od on od.oid=o.id inner join book b on b.id=od.bid";
//新的三表连接,取得book的值;
con=DaoFactory.getConnection();
pstmt=con.prepareStatement(sql);
ResultSet rs=pstmt.executeQuery();//执行结果放rs结果集;
Map<Order,ArrayList<Book>> map=new HashMap<Order,ArrayList<Book>>();
Order order=new Order();//订单对象,用于接收客户的多个订单项;
while(rs.next()){
int id=rs.getInt("id");//记录上次的一个id;6,如果和现在的id一致,则视为一个order
//直接继续,添加书本;
if(id!=order.getId()){
order.setId(rs.getInt("id"));
order.setCreatetime(rs.getDate("createtime"));
order.setTotal(rs.getDouble("total"));
}
//这个可以做好,不同订单,对应不同商品即1:1关系;不适合1:M关系;
//到此为止,已经获得了,订单的关键要素点,下面需要获得相应的订单,对应的商品详情了;
Book book=new Book();
book.setCount(rs.getInt("count"));
book.setPrice(rs.getFloat("transprice"));
book.setImage(rs.getString("image"));
book.setBookname(rs.getString("bookname"));
//设置图书表,然后添加到ArrayList里面;
if(map.get(order)==null){
ArrayList list=new ArrayList();
list.add(book);
map.put(order, list);
}else{
//应该在order不为空的情况下判断,是否重复;
ArrayList list=map.get(order);
list.add(book);
map.put(order, list);
}
}
DaoFactory.closeAll(rs, pstmt, con);
return map;
}
}
针对出现多个商品进入到一个订单的问题,已经给予解决了,其中的业务代码还可以继续修改,要继续等待哦。
OrderDaoImpl
public Map<Order, ArrayList<ShoppingItem>> getOrders(String condition,
PageControler pager) throws SQLException {
shoppingService ss = new shoppingService();
List<Order> rtn = new ArrayList<Order>(); //可能会存在1个客户有多个订单
String sql="select o.id,o.submittime,o.totalprice,b.bid,b.point,b.stock,di.bcount,b.bookname,b.b_price from d_order o inner join d_items di on di.orderId=o.id inner join d_books b on b.bid=di.bid";
//新的三表连接,取得book的值;
con=DaoFactory.getConnection();
pstmt=con.prepareStatement(sql);
ResultSet rs=pstmt.executeQuery();//执行结果放rs结果集;
Map<Order,ArrayList<ShoppingItem>> map=new HashMap<Order,ArrayList<ShoppingItem>>();
Order order=null;//订单对象,用于接收客户的多个订单项;
while(rs.next()){
if(order==null){
order=new Order(); //1.第一次,正常;
order.setId(rs.getInt("id"));
order.setSubmittime(rs.getString("submittime"));
order.setTotalprice(rs.getString("totalprice"));
ShoppingItem si = ss.declareShoppingItem(rs);
ArrayList list=new ArrayList();
list.add(si);
map.put(order, list);
}else{
if(order.getId()!=rs.getInt("id")){
order=new Order();
order.setId(rs.getInt("id"));
order.setSubmittime(rs.getString("submittime"));
order.setTotalprice(rs.getString("totalprice"));
ShoppingItem si = ss.declareShoppingItem(rs);
ArrayList list=new ArrayList();
list.add(si);
map.put(order, list);
}else{//证明是同一个订单;
ShoppingItem si = ss.declareShoppingItem(rs);
ArrayList list=map.get(order);
list.add(si);
map.put(order, list);
}
}
}
DaoFactory.closeAll(rs, pstmt, con);
return map;
}
Jsp电子商务之七 订单篇2的更多相关文章
- jsp电子商务系统之六 订单篇1
常规一个商品一个订单 多个商品一个订单 订单只有提交才能结算 付款页面 代码实现,主要是Servlet代码和Service业务层的代码,此处业务层,对多个dao的操作更为明显,体现业务二字!!! pa ...
- jsp电子商务购物车之五 数据库存储篇2
业务逻辑图,简单版要写各个Servlet //ChangeCartCountServlet 使用ajax实现数量,增加或减少; package com.cart.web; import java.io ...
- jsp电子商务购物车之四 数据库存储篇
为了方便用户下次登录,仍然可以看到自己的购物车内容,所以,需要在数据库存储相应的购物车项目,本处增加购物车项表;uid和bid是复合主键. package com.cart.entity; //购物车 ...
- jsp电子商务 购物车实现之三 购物车
CartServlet参考代码 : public void doPost(HttpServletRequest req, HttpServletResponse resp) throws Servle ...
- jsp电子商务 购物车实现之二 登录和分页篇
登录页面核心代码 <div id="login"> <h2>用户登陆</h2> <form method="post" ...
- jsp电子商务 购物车实现之一 设计篇
购物车的功能实现. 查询的资料,找到三种方法: 1.用cookie实现购物车: 2.用session实现购物车: 3.用cookie和数据库(购物车信息持久化)实现购物车: ============= ...
- JSP/JAVA目录清单
JAVA253中国象棋(CS) JAVA258网络五子棋游戏的设计与实现(CS) JAVA390停车场管理系统SQL(CS) JSP001学生综合素质测评系统JAVA+Mysql JSP002学生成绩 ...
- JSP应用开发 -------- 电纸书(未完待续)
http://www.educity.cn/jiaocheng/j9415.html JSP程序员常用的技术 第1章 JSP及其相关技术导航 [本章专家知识导学] JSP是一种编程语言,也是一种动 ...
- jsp前端实现分页代码
前端需要订一page类包装,其参数为 private Integer pageSize=10; //每页记录条数=10 private Integer totalCount; //总记录条数 priv ...
随机推荐
- iTextSharp动态生成多页pdf及追加内容等记录
1.要动态生成pdf,无非是用第三方或直接代码生成. 2.iTextSharp生成pdf问题点记录 dll相关下载 https://files.cnblogs.com/files/xlgwr/iTex ...
- java 素数问题
1.素数 质数定义为在大于1的自然数中,除了1和它本身以外不再有其他因数. 2.java 实现 一般都要用不能被自己和其他数字整除判断,jdk中已经有更好的实现方法了. List<BigInte ...
- Qt-Qml-隐藏标题栏-程序依附任务栏
最近换工作,直接欢动qml这边来了,以后可能会有更多关于qml的文章 今天第一个,qml下面怎么隐藏标题栏 第一种方法是在使用QQuickView加载qml文件的话,这里就可以使用QQuickView ...
- AirtestIDE实践一:梦幻西游手游师门任务自动化
Airtest Project是网易自研的游戏自动化项目.Airtest IDE是这个项目的一个IDE,就像Eclipse.Pycharm一样,是一个集成开发工具.Airtest框架是一个基于Open ...
- myeclipse tomcat部署按钮点击没反应
进入workspace目录,删除.metadata\.plugins\org.eclipse.core.runtime\.settings\com.genuitec.eclipse.ast.deplo ...
- 牛客网暑期ACM多校训练营(第五场):F - take
链接:牛客网暑期ACM多校训练营(第五场):F - take 题意: Kanade有n个盒子,第i个盒子有p [i]概率有一个d [i]大小的钻石. 起初,Kanade有一颗0号钻石.她将从第1到第n ...
- 国内版Office365实现MFA的方案(未完)
现在二十一世纪互联版也可以实现了MFA,现在也就是2017年3月份,支持了PC,但是对移动端应用还是不支持的,请了解. 具体方法如下: 登录国内版Office365(事例为高级商业版 https:// ...
- LeetCode 104——二叉树中的最大深度
1. 题目 2. 解答 如果根节点为空,直接返回 0.如果根节点非空,递归得到其左右子树的深度,树的深度就为左右子树深度的最大值加 1. /** * Definition for a binary t ...
- LeetCode - 463. Island Perimeter - O(MN)- (C++) - 解题报告
原题 原题链接 You are given a map in form of a two-dimensional integer grid where 1 represents land and 0 ...
- SGU 176 Flow construction(有源汇上下界最小流)
Description 176. Flow construction time limit per test: 1 sec. memory limit per test: 4096 KB input: ...