JavaWeb学习记录(十三)——商城购物之添加订单的数据库级联操作
一、方法实现
private JdbcTemplate jdbcTemplate = new JdbcTemplate(DBConn.getDataSource());
@SuppressWarnings("deprecation")
@Override
public boolean insertObject(Orders entity) {
String sql1 = "insert into orders(number,status,uid) values(?,?,?)";
// 保存订单
int num1 = jdbcTemplate.update(sql1, new Object[] { entity.getNumber(),
"未付款", entity.getUser().getId() });
if (num1 > 0) {
//获取订单id
int id = jdbcTemplate.queryForInt(
"select id from orders where number=?", entity.getNumber());
//设置订单id
entity.setId(id);
boolean flag = false;
// 保存订单详情
List<OrdersItem> ordersItems = entity.getOrdersItems();
String sql2 = "insert into ordersItem(gid,num,price,oid)values(?,?,?,?)";
if (ordersItems != null) {
for (OrdersItem item : ordersItems) {
// 保存订单条目
int num2 = jdbcTemplate.update(
sql2,
new Object[] { item.getGoods().getId(),
item.getNum(), item.getPrice(),
item.getOrders().getId() });
if (num2 > 0) {
} else {
flag = true;
break;
}
}
if (flag) {
System.out.println("OrdersItem 有一个插入失败");
} else {
// 查出总价格
String sql3 = "select sum(price) as sum from ordersItem where oid=?";
Double sum = jdbcTemplate.queryForObject(sql3,
new RowMapper<Double>() {
@Override
public Double mapRow(ResultSet rs, int arg1)
throws SQLException {
// TODO Auto-generated method stub
return rs.getDouble("sum");
}
}, entity.getId());
// 更新订单总价格
String sql4 = "update orders set sum=? where id=?";
int num3 = jdbcTemplate.update(sql4, new Object[] { sum,
entity.getId() });
if (num3 > 0) {
System.out.println("更新成功");
} else {
System.out.println("更新失败");
}
}
} else {
System.out.println("订单插入失败");
}
}
return false;
}
二、测试
public class OrderTest {
private OrdersDao ordersDao=new OrdersDaoImpl();
@Test
public void test1(){
Orders orders=new Orders();
orders.setNumber("0x0014");
User u=new User();
u.setId(1);
orders.setUser(u);
//创建一个订单集合
List<OrdersItem> ordersItems=new ArrayList<OrdersItem>();
Goods goods=new Goods(1, "", 5000, null, null);
OrdersItem item1=new OrdersItem(goods, 3, 3*goods.getPrice(), orders);
ordersItems.add(item1);
Goods goods1=new Goods(2, "", 11, null, null);
OrdersItem item2=new OrdersItem(goods1, 3, 3*goods1.getPrice(), orders);
ordersItems.add(item2);
orders.setOrdersItems(ordersItems);
ordersDao.insertObject(orders);
}
}
三、事务处理的方法
private JdbcTemplate jdbcTemplate = new JdbcTemplate(DBConn.getDataSource());
@Override
public boolean insertObject(final Orders entity) {
//事务处理,保证下面的语句要么全都执行,要么全都不执行
//事务管理对象
PlatformTransactionManager transactionManager=new DataSourceTransactionManager(DBConn.getDataSource());
//事务管理的模板对象
TransactionTemplate template=new TransactionTemplate(transactionManager);
//执行操作
return template.execute(new TransactionCallback<Boolean>() {
@Override
public Boolean doInTransaction(TransactionStatus ts) {
String sql1 = "insert into orders(number,status,uid) values(?,?,?)";
// 保存订单
int num1 = jdbcTemplate.update(sql1, new Object[] { entity.getNumber(),
"未付款", entity.getUser().getId() });
if (num1 > 0) {
//获取订单id
@SuppressWarnings("deprecation")
int id = jdbcTemplate.queryForInt(
"select id from orders where number=?", entity.getNumber());
//设置订单id
entity.setId(id);
boolean flag = false;
// 保存订单详情
List<OrdersItem> ordersItems = entity.getOrdersItems();
String sql2 = "insert into ordersItem(gid,num,price,oid)values(?,?,?,?)";
if (ordersItems != null) {
for (OrdersItem item : ordersItems) {
// 保存订单条目
int num2 = jdbcTemplate.update(
sql2,
new Object[] { item.getGoods().getId(),
item.getNum(), item.getPrice(),
item.getOrders().getId() });
if (num2 > 0) {
} else {
flag = true;
break;
}
}
if (flag) {
System.out.println("OrdersItem 有一个插入失败");
ts.setRollbackOnly();
return false;
} else {
// 查出总价格
String sql3 = "select sum(price) as sum from ordersItem where oid=?";
Double sum = jdbcTemplate.queryForObject(sql3,
new RowMapper<Double>() {
@Override
public Double mapRow(ResultSet rs, int arg1)
throws SQLException {
// TODO Auto-generated method stub
return rs.getDouble("sum");
}
}, entity.getId());
// 更新订单总价格
String sql4 = "update orders set sum=? where id=?";
int num3 = jdbcTemplate.update(sql4, new Object[] { sum,
entity.getId() });
if (num3 > 0) {
System.out.println("更新成功");
return true;
} else {
System.out.println("更新失败");
ts.setRollbackOnly();
return false;
}
}
} else{
return true;
}
}else {
System.out.println("订单插入失败");
ts.setRollbackOnly();
return false;
}
}
});
}
JavaWeb学习记录(十三)——商城购物之添加订单的数据库级联操作的更多相关文章
- (转)JavaWeb学习总结(十三)——使用Session防止表单重复提交
如何防止表单重复提交 在平时开发中,如果网速比较慢的情况下,用户提交表单后,发现服务器半天都没有响应,那么用户可能会以为是自己没有提交表单,就会再点击提交按钮重复提交表单,我们在开发中必须防止表单重复 ...
- JavaWeb学习记录(十四)——商城购物之字符串拼接实现最近浏览商品和购物车的功能
一.字符串拼接的工具类 package blank.util; import java.util.Iterator;import java.util.Map;import java.util.Set; ...
- JavaWeb学习记录(十二)——商城购物之数据库操作的接口定义
一.基本接口,该项目中所有接口都继承它 package blank.dao; import java.util.List; public interface BaseDao<T,PK> { ...
- JavaWeb学习记录(二十三)——文件上传与下载
一.导入jar包
- javaweb学习记录(1)
Java基础学习笔录 1.运行java程序,出现bad version number in.class file 编译器()的版本号高于运行环境(jre)的版本号,可以降低编译器版本号,也可以通过提升 ...
- JavaWeb学习记录(七)——MVC操作数据库增删改查与分页功能
一.分页工具类 package blank.util;import java.util.List; import org.springframework.jdbc.core.JdbcTemplate; ...
- JavaWeb学习记录(二十一)——国际化处理
¨国际化又称为 i18n:internationalization ¨对于软件中的菜单栏.导航条.错误提示信息,状态信息等这些固定不变的文本信息,可以把它们写在一个properties文件中,并根据不 ...
- javaweb学习总结十三(dom4j方式对XML文档进行解析以及Xpath的使用)
一:dom4j方式介绍 对于xml的解析总共有三种 1:jaxp方式,是sun公司开发的,分为sax方式和dom方式 2:jdom方式,后来其中部分人员参与开发dom4j 3:dom4j方式,是现在企 ...
- JavaWeb学习总结(十三)——使用Session防止表单重复提交
在平时开发中,如果网速比较慢的情况下,用户提交表单后,发现服务器半天都没有响应,那么用户可能会以为是自己没有提交表单,就会再点击提交按钮重复提交表单,我们在开发中必须防止表单重复提交. 一.表单重复提 ...
随机推荐
- [开发笔记]-WindowsService服务程序开发
Windows服务:Microsoft Windows 服务(即,以前的 NT服务)使您能够创建在它们自己的 Windows 会话中可长时间运行的可执行应用程序.这些服务可以在计算机启动时自动启动,可 ...
- 类似github的框架
github是程序员经常上的网站,但如果是在一家苦逼不能访问外网的公司,那不能把自己的代码托管在github上绝对是一件非常痛苦的事情.如果想要在公司内网也可以用github托管自己的代码,那就要自己 ...
- wince6.0 开机启动定制的程序
1.prject.bib MediaApp.exe $(_FLATRELEASEDIR)\MediaApp.exe NK H MediaApp.lnk $(_FLATRELEASEDIR)\Media ...
- dataTable/dataSet转换成Json格式
using System.Text;using System.Collections.Generic; 1)dataTable转Json(表格有名称:dt.TableName) public stat ...
- 手机app常见bug积累
经过一年的测试工作,以下是手机APP比较容易出现的错误.之后如果发现了还会继续添加,修改.1.翻页手机客户端,内容超过一页时,上拉加载更多内容,加载错误(容易出现数据重复,图片和文章不匹配,图片重复加 ...
- c# access插入null值
c# 插入access数据库 提示错误: Parameter @DeviceLocation has no default value. 参数@DeviceLocation 的有没有默认值. Stri ...
- Python开发入门与实战1-开发环境
1.搭建Python Django开发环境 1.1.Python运行环境安装 Python官网:http://www.python.org/ Python最新源码,二进制文档,新闻资讯等可以在Pyth ...
- python 接口开发(一)
cmd中,提示pip版本太低,先升级pip pip install --upgrade pip (pip,安装和管理python扩展包的工具) cmd下,pip,出现详细信息证明装成功了 pip ...
- POJ 2752 - Seek the Name, Seek the Fame (KMP)
题意:给一个字符串s,问s的某个前缀与后缀相同的情况时,长度是多少. 此题使用KMP的next数组解决. next数组中,j=next[i],next[i]表示S[0...i-1]的某个后缀(字符串S ...
- (转)HTML5开发学习(3):本地存储之Web Sql Database
原文:http://www.cnblogs.com/xumingxiang/archive/2012/03/25/2416386.html HTML5开发学习(3):本地存储之Web Sql Data ...