how2j.cn

相关下载
文件名 文件大小
cart.rar 883k
使用站长秘制下载工具

工具版本兼容问题
在购物车页面,增加一个创建订单的超链

通过创建订单,在Order表里新增一条数据,同时把session中的订单条目都保存到数据库中。

步骤 1 : SQL   
步骤 2 : Order   
步骤 3 : OrderItem   
步骤 4 : OrderDAO   
步骤 5 : OrderItemDAO   
步骤 6 : listOrderItem.jsp   
步骤 7 : OrderCreateServlet   
步骤 8 : 配置web.xml   
步骤 9 : 测试   

步骤 1 :

SQL

创建order表,里面有一个uid字段用于表明该订单属于哪个用户
注: order是关键字,不能直接用作表名,通常的做法是加一个下划线order_

创建orderitem,表里有id,pid,num,oid等字段。 分别表示主键,商品对应的id,购买数量以及订单id。
create table order_( id int AUTO_INCREMENT, uid int, primary key(id) ); create table orderitem( id int AUTO_INCREMENT, pid int, num int, oid int, primary key(id) );
create table order_(
  id int AUTO_INCREMENT,
  uid int,
  primary key(id)
);

create table orderitem(
  id int AUTO_INCREMENT,
  pid int,
  num int,
  oid int,
  primary key(id)
);
步骤 2 :

Order

OrderItem类似的,会有一个User属性,而不是使用int类型的uid。
package bean; public class Order { int id; User user; public int getId() { return id; } public void setId(int id) { this.id = id; } public User getUser() { return user; } public void setUser(User user) { this.user = user; } }
package bean;

public class Order {

	int id;
	User user;
	public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public User getUser() {
		return user;
	}
	public void setUser(User user) {
		this.user = user;
	}
}
步骤 3 :

OrderItem

OrderItem在原来的基础上,增加一个Order属性
package bean; public class OrderItem { private int id; private Product product; private int num; private Order order; public Order getOrder() { return order; } public void setOrder(Order order) { this.order = order; } public int getId() { return id; } public void setId(int id) { this.id = id; } public Product getProduct() { return product; } public void setProduct(Product product) { this.product = product; } public int getNum() { return num; } public void setNum(int num) { this.num = num; } }
步骤 4 :

OrderDAO

OrderDAO把订单对象保存到数据库中。

这里需要注意的是,Order对象保存到数据库中后,该对象就会有对应的id,这个id,在后续保存OrderItem的时候,是作为order id存在的。

所以在保存的数据库的时候,要获取自增长id

ResultSet rs = ps.getGeneratedKeys();
if (rs.next()) {
int id = rs.getInt(1);
o.setId(id);
}
package dao; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import bean.Order; public class OrderDAO { public void insert(Order o) { try { Class.forName("com.mysql.jdbc.Driver"); Connection c = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/cart?characterEncoding=UTF-8", "root", "admin"); String sql = "insert into order_ values(null,?)"; PreparedStatement ps = c.prepareStatement(sql); ps.setInt(1, o.getUser().getId()); ps.execute(); ResultSet rs = ps.getGeneratedKeys(); if (rs.next()) { int id = rs.getInt(1); o.setId(id); } ps.close(); c.close(); } catch (ClassNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }
步骤 5 :

OrderItemDAO

将OrderItem保存到数据库中
package dao; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.util.ArrayList; import java.util.List; import bean.OrderItem; import bean.Product; public class OrderItemDAO { public static void main(String[] args) { } public void insert(OrderItem oi) { try { Class.forName("com.mysql.jdbc.Driver"); Connection c = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/cart?characterEncoding=UTF-8", "root", "admin"); String sql = "insert into orderitem values(null,?,?,?)"; PreparedStatement ps = c.prepareStatement(sql); ps.setInt(1,oi.getProduct().getId()); ps.setInt(2,oi.getNum()); ps.setInt(3,oi.getOrder().getId()); ps.execute(); ps.close(); c.close(); } catch (ClassNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }
步骤 6 :

listOrderItem.jsp

在listOrderItem.jsp页面新增加一个"生成订单"的链接

<c:if test="${!empty ois}">
<tr>
<td colspan="4" align="right">
<a href="/createOrder">生成订单</a>
</td>
</tr>
</c:if>
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" import="java.util.*" isELIgnored="false"%> <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> <h1 align="center" >购物车</h1> <table align='center' border='1' cellspacing='0'> <tr> <td>商品名称</td> <td>单价</td> <td>数量</td> <td>小计</td> </tr> <c:forEach items="${ois}" var="oi" varStatus="st"> <tr> <td>${oi.product.name}</td> <td>${oi.product.price}</td> <td>${oi.num}</td> <td>${oi.product.price*oi.num}</td> </tr> </c:forEach> <c:if test="${!empty ois}"> <tr> <td colspan="4" align="right"> <a href="createOrder">生成订单</a> </td> </tr> </c:if> </table>
步骤 7 :

OrderCreateServlet

OrderCreateServlet创建订单的Servlet
1. 首选判断用户是否登陆,如果没有登陆跳转到登陆页面
2. 创建一个订单对象,并设置其所属用户
3. 把该订单对象保存到数据库中
4. 遍历session中所有的订单项,设置他们的Order。 然后保存到数据库中
5. 清空session中的订单项
6. 最后打印订单创建成功
package servlet; import java.io.IOException; import java.util.List; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import bean.Order; import bean.OrderItem; import bean.User; import dao.OrderDAO; import dao.OrderItemDAO; public class OrderCreateServlet extends HttpServlet { protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { User u = (User) request.getSession().getAttribute("user"); if(null==u){ response.sendRedirect("/login.jsp"); return; } Order o = new Order(); o.setUser(u); new OrderDAO().insert(o); List<OrderItem> ois = (List<OrderItem>) request.getSession().getAttribute("ois"); for (OrderItem oi : ois) { oi.setOrder(o); new OrderItemDAO().insert(oi); } ois.clear(); response.setContentType("text/html; charset=UTF-8"); response.getWriter().println("订单创建成功"); } }
步骤 8 :

配置web.xml

<?xml version="1.0" encoding="UTF-8"?> <web-app> <servlet> <servlet-name>ProductListServlet</servlet-name> <servlet-class>servlet.ProductListServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>ProductListServlet</servlet-name> <url-pattern>/listProduct</url-pattern> </servlet-mapping> <servlet> <servlet-name>UserLoginServlet</servlet-name> <servlet-class>servlet.UserLoginServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>UserLoginServlet</servlet-name> <url-pattern>/login</url-pattern> </servlet-mapping> <servlet> <servlet-name>OrderItemAddServlet</servlet-name> <servlet-class>servlet.OrderItemAddServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>OrderItemAddServlet</servlet-name> <url-pattern>/addOrderItem</url-pattern> </servlet-mapping> <servlet> <servlet-name>OrderItemListServlet</servlet-name> <servlet-class>servlet.OrderItemListServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>OrderItemListServlet</servlet-name> <url-pattern>/listOrderItem</url-pattern> </servlet-mapping> <servlet> <servlet-name>OrderCreateServlet</servlet-name> <servlet-class>servlet.OrderCreateServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>OrderCreateServlet</servlet-name> <url-pattern>/createOrder</url-pattern> </servlet-mapping> </web-app>
步骤 9 :

测试

点击创建订单后,在数据库中的orderitem表观察到插入的数据
测试


HOW2J公众号,关注后实时获知布最新的教程和优惠活动,谢谢。


问答区域    
2018-06-04 <a href="/createOrder">生成订单</a> 路径报错,无法生成订单
汪昕港
listOrderItem.jsp里的路径有问题吧 我改成 <a href="/cart/createOrder">生成订单</a> 才数据插到数据库








答案 或者 代码至少填写一项, 如果是自己有问题,请重新提问,否则站长有可能看不到




2018-03-30 关于OrderCreateServlet和OrderItemDAO的代码缺陷
morph



OrderItemDAO类中,将order的id插入到orderitem表的oid,这里oi.getOrder().getId()实际上不会得到order的id,因为OrderCreateServlet类根本就没从数据库中取出id。
ps.setInt(3,oi.getOrder().getId());
orderitem的oid都为0,没有取到order的id。


6 个答案

Little_Monkey 答案时间:2018-07-06
可能跟你的 mysql 的Jar包 有关系, 你如果使用的时5.1.7的版本, ResultSet rs = ps.getGeneratedKeys(); 获取主键id 这个语句会报异常,虽然程序还是正常运行了。但是你可以看看控制台。。。。。。就不会获得主键Id,

啾啾啾 答案时间:2018-05-17
应该是不用添加的,因为你是先添加的order进数据库中,在OrderDAO中的insert方法里,有一段是获取自增id并赋值给当前传入对象的代码,所以是能够获取的。

borrowface 答案时间:2018-05-14
if (rs.next()) { int id=rs.getInt(1); o.setId(id); }
我做的没有问题呢,你所说的那里仔细看下OrderDAO这个类中的这一段

java_web_greenhand 答案时间:2018-04-19
Order o = new Order(); o.setUser(u); new OrderDAO().insert(o); 这里在将Order o插入数据库的时候,重新获取并设置了Order o的id,因此后面的oi.getOrder().getId()是正确的。 实际上的问题是将Order o插入到数据库的代码写错了,正确的代码应该是: String sql = "insert into order_(uid) values(?)"; PreparedStatement ps = c.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS); ps.setInt(1, o.getUser().getId());

zhao139 答案时间:2018-04-09
刚做完也发现这个问题了

morph 答案时间:2018-03-30
所以应该在OrderDAO中增加getOrderID的方法,并且在OrderCreateServlet中,将id,set给order。




答案 或者 代码至少填写一项, 如果是自己有问题,请重新提问,否则站长有可能看不到





2018-02-05 订单项为什么保存到数据库?淘宝这样做的?
2018-01-25 不明参数
2017-12-11 大大,为什么会有validateJarFile这种报错
2017-10-31 如何调整默认跳转网址路径
2017-08-17 做完后测试提交订单数据库中并没有数据。
2017-08-13 存在的改进?
2017-06-24 关于数据库的问题
2017-06-16 步骤 6 : listOrderItem.jsp 里面的代码不一致
2017-03-29 加入到购物车后不创建订单,返回登陆界面,登陆另一个人的帐号,则后者的购物车里有前一个帐号买的东西




提问之前请登陆
关于 J2EE-购物车-订单模块 的提问

尽量提供截图代码异常信息,有助于分析和解决问题。 也可进本站QQ群交流: 620943819
提问尽量提供完整的代码,环境描述,越是有利于问题的重现,您的问题越能更快得到解答。
对教程中代码有疑问,请提供是哪个步骤,哪一行有疑问,这样便于快速定位问题,提高问题得到解答的速度
在已经存在的几千个提问里,有相当大的比例,是因为使用了和站长不同版本的开发环境导致的,比如 jdk, eclpise, idea, mysql,tomcat 等等软件的版本不一致。
请使用和站长一样的版本,可以节约自己大量的学习时间。 站长把教学中用的软件版本整理了,都统一放在了这里, 方便大家下载: http://how2j.cn/k/helloworld/helloworld-version/1718.html

上传截图