@Transactional
public String dealBusiness(BuyCart buyCart,User user) {
String res="fail";
int compareResult=0;
try {
buyCart.getBuyCartDeal().setUser(user);
buyCart.getBuyCartDeal().setTotalMoney(Double.valueOf(buyCart.getTotalPrice().toString()));
Set<String> keySet = buyCart.getShopCartMap().keySet();
for(String key : keySet){
buyCart.getBuyCartDeal().getBuyCommoditiesSet().add(buyCart.getShopCartMap().get(key)) ;
}
Account account=this.getAccountService().select(user.getId(),"");
SiteConfig siteConfig=this.getSiteConfigService().getCurrentSiteConfig();
BigDecimal bigDecimal=new BigDecimal(buyCart.getBuyCartDeal().getTotalMoney());//购物车中所有商品的总价格
compareResult=account.getRemainingMoney().compareTo(bigDecimal);
if (compareResult!=-1) {
//持久化对象
buyCart.getBuyCartDeal().setDeliveryTime(getcurrent());
buyCart.getBuyCartDeal().setStatus(3);
String result=this.getBuyCartDealDao().insert(buyCart.getBuyCartDeal());
//从买家账户扣钱
BuyAccountOperation buyAccountOpertation=new BuyAccountOperation();
buyAccountOpertation.setBuyCartDeal(buyCart.getBuyCartDeal());
buyAccountOpertation.setOperationType(4);
buyAccountOpertation.setOperationTime(getcurrent());
buyAccountOpertation.setMoneyUnit("元");
buyAccountOpertation.setAccount(account);
buyAccountOpertation.setMoney(bigDecimal);
buyAccountOpertation.setSiteConfig(siteConfig);
this.getBuyAccountOperationService().insert(buyAccountOpertation);
account.setRemainingMoney(account.getRemainingMoney().subtract(bigDecimal));
this.getAccountService().update(account);
account.setTotalMoney(account.getRemainingMoney());
this.getAccountService().update(account);
//给管理员以及发布图片的用户分钱
BigDecimal bigDecimal2=new BigDecimal(0);
for (BuyCommodities buyCommodities:buyCart.getBuyCartDeal().getBuyCommoditiesSet()) {
buyCommodities.setBuyCartDeal(buyCart.getBuyCartDeal());
Publish publish=buyCommodities.getPublish();
this.getBuyCommoditiesService().insert(buyCommodities);
Account account2=this.getAccountService().select(3,"");
User user2=buyCommodities.getPublish().getUser();
Account account3=this.getAccountService().select(user2.getId(),"");
BigDecimal tax=new BigDecimal(siteConfig.getTax());
BigDecimal third=new BigDecimal(siteConfig.getThirdPayRate());
BigDecimal other=new BigDecimal(0.15);
BigDecimal remain=new BigDecimal(0);
BigDecimal adminTotal=new BigDecimal(0);
if (buyCommodities.getCopyrightOrUsage()==0) {
bigDecimal2=new BigDecimal(buyCommodities.getPublish().getUsagePrice());
adminTotal=bigDecimal2.multiply(tax).add(bigDecimal2.multiply(third)).add(bigDecimal2.multiply(other));
account2.setRemainingMoney(account2.getRemainingMoney().add(adminTotal));
}else if (buyCommodities.getCopyrightOrUsage()==1) {
bigDecimal2=new BigDecimal(buyCommodities.getPublish().getCopyrightPrice());
adminTotal=bigDecimal2.multiply(tax).add(bigDecimal2.multiply(third)).add(bigDecimal2.multiply(other));
account2.setRemainingMoney(account2.getRemainingMoney().add(adminTotal));
}else if (buyCommodities.getCopyrightOrUsage()==2) {
BigDecimal bigDecimal3=new BigDecimal(buyCommodities.getPublish().getCopyrightPrice());
BigDecimal bigDecimal4=new BigDecimal(buyCommodities.getPublish().getUsagePrice());
bigDecimal2=bigDecimal3.add(bigDecimal4);
adminTotal=bigDecimal2.multiply(tax).add(bigDecimal2.multiply(third)).add(bigDecimal2.multiply(other));
account2.setRemainingMoney(account2.getRemainingMoney().add(adminTotal));
}
remain=bigDecimal.subtract(account2.getRemainingMoney());
account3.setRemainingMoney(account3.getRemainingMoney().add(remain));
BuyAccountOperation buyAccountOperation=new BuyAccountOperation();
buyAccountOperation.setBuyCartDeal(buyCart.getBuyCartDeal());
buyAccountOperation.setOperationTime(getcurrent());
buyAccountOperation.setOperationType(3);
buyAccountOperation.setMoney(adminTotal);
buyAccountOperation.setAccount(account2);
buyAccountOperation.setMoneyUnit("元");
buyAccountOperation.setSiteConfig(siteConfig);
this.getBuyAccountOperationService().insert(buyAccountOperation);
this.getAccountService().update(account2);
account2.setTotalMoney(account2.getRemainingMoney());
this.getAccountService().update(account2);
BuyAccountOperation buyAccountOperation2=new BuyAccountOperation();
buyAccountOperation2.setBuyCartDeal(buyCart.getBuyCartDeal());
buyAccountOperation2.setOperationTime(getcurrent());
buyAccountOperation2.setOperationType(3);
buyAccountOperation2.setMoney(remain);
buyAccountOperation2.setAccount(account3);
buyAccountOperation2.setMoneyUnit("元");
buyAccountOperation2.setSiteConfig(siteConfig);
this.getBuyAccountOperationService().insert(buyAccountOperation2);
this.getAccountService().update(account3);
account3.setTotalMoney(account3.getRemainingMoney());
this.getAccountService().update(account3);
}
buyCart.getBuyCartDeal().setStatus(5);
buyCart.getBuyCartDeal().setDeliveryTime(getcurrent());
this.getBuyCartDealDao().update(buyCart.getBuyCartDeal());
res="suc";
}
} catch (Exception e) {
// TODO: handle exception
res="fail";
buyCart.getBuyCartDeal().setStatus(4);
buyCart.getBuyCartDeal().setDeliveryTime(getcurrent());
boolean b=this.getBuyCartDealDao().update(buyCart.getBuyCartDeal());
if (b) {
res="not";
}else {
b=false;
}
}
return res;
}
- 浏览: 51577 次
文章分类
最新评论
发表评论
-
java 如何判断操作系统是Linux还是Windows
2014-02-11 09:59 855System.out.println("== ... -
MyEclipse控制台输入中文乱码解决
2013-11-21 22:46 1395修改MyEclipse的配置文件,在myeclipse的安装目 ... -
struts2 <result type="redirect">
2013-11-21 12:12 683今天在用struts2在做项目时候,从一个action我想跳转 ... -
ref bean与ref local区别
2013-11-08 09:32 430<bean id="userDAOPro ... -
win7 系统中host文件的位置
2013-10-31 11:06 693C:\Windows\System32\drivers\etc ... -
MyEclipse设置JSP页面默认编码方式以及设置在Java文件中作者、日期等说明
2013-10-24 17:48 569MyEclipse设置JSP页面默认编码方式: windo ... -
获取当前的准确时间
2013-09-16 12:10 664Calendar c=Calendar.getInstance ... -
myeclipse中svn图标状态(同步标记)不显示问题的解决方法
2013-09-05 10:21 649今天从SVN服务器上down下工程后,发现myeclipse ... -
hibernate Criteria
2013-08-05 10:31 588方法 描述 Expressio ... -
比较大小
2013-08-04 17:13 527int a=5000; int b=5000; a==b ... -
时间类型的转化
2013-05-29 15:09 689SimpleDateFormat df=new SimpleD ... -
java list 判断对象是否存在
2013-11-11 15:20 4262String tags=this.getPublish() ... -
GET方式传中文参数给Struts2 Action时出现乱码
2013-05-10 09:43 1048GET方式传中文参数给Struts2 Action时出现乱码 ... -
proteced 作用范围
2013-04-27 19:27 596struts2 ajax 页面得不到类中的变量的值。可能是因 ... -
自动生成java注册码的java代码
2013-04-02 16:47 0import java.io.BufferedReader ... -
hibernate查询的6种方法
2013-03-23 10:22 454hibernate查询的6种方法。分别是HQL查询,对象化查 ... -
hibernate Criteria DetachedCriteria
2013-03-23 10:11 545Criteria 是在线的,所 以它是由 Hibernat ... -
支付宝源码
2013-03-22 11:16 562支付宝的相关操作 -
java获得图片的像素
2013-03-22 10:21 708ImageIcon img= new Imag ... -
java 发邮件
2013-03-21 14:31 765package com.qhkj.goodChance.c ...
相关推荐
MySQL临时表是一种在会话范围内创建的特殊类型的表,它仅对当前会话可见,并在会话结束时自动删除。这种技术在处理复杂查询、中间数据处理或报表生成时非常有用,因为它允许用户将查询结果暂存起来,以便进一步处理...
系统临时文件和IE临时文件是计算机使用过程中不可避免的产物,它们在日常操作中扮演着重要角色,但也可能随着时间的推移占用大量磁盘空间,甚至成为隐私泄露的风险。因此,定期清理这些临时文件是保持系统运行高效且...
### Oracle 临时表用法详解 #### 一、背景与问题描述 在处理数据库操作时,经常遇到因数据量庞大而导致处理效率降低的问题。例如,某个报表中心的存储过程执行速度过慢,其中一个原因是该过程涉及到一个中间表,...
该系统主要是一个基于Web的临时文件上传和分享平台,它为用户提供了一个便捷的方式来存储和分享临时文件。系统的核心功能包括文件上传、存储管理和链接分享,适用于个人或团队间快速交换临时性文件。以下是对该系统...
Java 实现上传网络图片到微信临时素材 在本文中,我们将详细介绍如何使用 Java 语言实现上传网络图片到微信临时素材。微信临时素材是指微信服务器上的一种临时存储形式,通过上传图片到微信临时素材,我们可以在...
本篇文章将深入探讨如何在Oracle存储过程中使用临时表,包括会话级临时表和事务级临时表。 ### 会话级临时表 会话级临时表(Session-Level Temporary Tables)只在创建它的会话内可见,并且在会话结束时自动删除。...
临时表本质上是一种cache的表现形式,Oracle的临时表都是事先建好的,一旦用了临时表,存放的是和本会话相关的数据,没有人会傻乎乎地用临时表来保存本应该共享的数据。 with子查询实际上也是用了临时表,...
本文将详细讲解如何利用C#来获取IPv4和IPv6地址,特别是当存在临时IPv6地址时如何优先选择这些地址。 首先,我们需要了解IPv4和IPv6的基本概念。IPv4是第四版互联网协议,它使用32位地址,最多可以表示约42亿个不同...
临时邮箱是一种短期、一次性使用的电子邮箱地址,常用于保护个人隐私、避免垃圾邮件或测试目的。在线生成器是提供这种服务的平台,用户无需注册,只需简单操作即可获得临时邮箱地址。下面将详细介绍临时邮箱在线生成...
在日常使用过程中,MapGIS会自动生成一些临时备份文件,这些文件通常带有“~”符号作为前缀,以保护用户在操作时的数据安全。然而,随着时间的推移,这些临时备份文件可能会占用大量的硬盘空间,影响计算机性能。...
SQL Server 中的临时表概念、创建和插入数据等问题 SQL Server 中的临时表概念是指名称以井号 (#) 开头的表,如果当用户断开连接时没有除去临时表,SQL Server 将自动除去临时表。临时表有两种类型:本地临时表和...
主流数据库中临时表的使用 在主流数据库中,临时表是一种特殊类型的表,它们是临时存储数据的容器。临时表可以在不同的数据库管理系统中使用,本文将对 MS SQLSERVER、Oracle 和 DB2 中的临时表进行介绍。 MS SQL ...
### JavaScript 获取浏览器临时目录知识点详解 #### 一、概述 在Web开发中,有时需要获取浏览器的临时目录以便进行文件操作或数据缓存等任务。然而,由于浏览器安全策略的限制,JavaScript直接获取本地文件系统...
Oracle中的临时表是一种特殊的数据结构,用于存储会话或事务期间的数据,这些数据仅对当前会话可见,并在特定条件下自动清除。Oracle提供两种类型的临时表:事务型和会话型。 事务型临时表在事务开始时创建,插入的...
SQL Server 触发器中自动生成的临时表 SQL Server 触发器是一种强大的工具,用于自动执行某些操作,以响应数据库中的变化。其中,系统自动生成的临时表是触发器中一个重要的组成部分。今天,我们将详细介绍 SQL ...
在FlexSim中,“临时实体类型”(Temporary Entity Type)是一个关键概念,它允许用户自定义临时实体,以适应特定的模拟场景。这些实体可以在运行时动态创建和销毁,根据模型的需求来变化,为建模提供了极大的灵活性...
在VB(Visual Basic)编程环境中,获取和处理临时文件是一项常见的任务,特别是在开发涉及数据存储、备份或系统恢复的应用程序时。临时文件通常用于存放临时数据,这些数据可能在程序运行过程中产生,但不需要长期...
解决 Oracle 临时表空间满的问题需要通过查看当前数据库的默认临时表空间、查看当前临时表空间的大小、创建新的临时表空间、将新建的临时表空间设置为数据库的默认临时表空间、删除原来的临时表空间、创建新的临时表...
在Java编程语言中,创建多个临时文件是常见的需求,特别是在测试、数据处理或者临时存储一些信息时。要实现这个功能,我们需要使用Java的`java.io.File`类和`java.nio.file.Files`类提供的方法。接下来,我们将详细...
在IT行业中,临时文件是操作系统或应用程序在执行过程中创建的临时性数据存储,它们通常用于存储中间结果、缓存信息或者在多步骤操作中传递数据。临时文件的保存位置是系统管理和优化工作流程的关键因素,因为正确...