`

临时的

 
阅读更多

@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;
    }

分享到:
评论

相关推荐

    mysql临时表用法分析【查询结果可存在临时表中】

    MySQL临时表是一种在会话范围内创建的特殊类型的表,它仅对当前会话可见,并在会话结束时自动删除。这种技术在处理复杂查询、中间数据处理或报表生成时非常有用,因为它允许用户将查询结果暂存起来,以便进一步处理...

    系统临时文件和IE临时文件清除

    系统临时文件和IE临时文件是计算机使用过程中不可避免的产物,它们在日常操作中扮演着重要角色,但也可能随着时间的推移占用大量磁盘空间,甚至成为隐私泄露的风险。因此,定期清理这些临时文件是保持系统运行高效且...

    Oracle 临时表用法

    ### Oracle 临时表用法详解 #### 一、背景与问题描述 在处理数据库操作时,经常遇到因数据量庞大而导致处理效率降低的问题。例如,某个报表中心的存储过程执行速度过慢,其中一个原因是该过程涉及到一个中间表,...

    最新临时文件上传存储分享系统,临时文件网盘系统源码

    该系统主要是一个基于Web的临时文件上传和分享平台,它为用户提供了一个便捷的方式来存储和分享临时文件。系统的核心功能包括文件上传、存储管理和链接分享,适用于个人或团队间快速交换临时性文件。以下是对该系统...

    java实现上传网络图片到微信临时素材

    Java 实现上传网络图片到微信临时素材 在本文中,我们将详细介绍如何使用 Java 语言实现上传网络图片到微信临时素材。微信临时素材是指微信服务器上的一种临时存储形式,通过上传图片到微信临时素材,我们可以在...

    Oracle存储过程中使用临时表

    本篇文章将深入探讨如何在Oracle存储过程中使用临时表,包括会话级临时表和事务级临时表。 ### 会话级临时表 会话级临时表(Session-Level Temporary Tables)只在创建它的会话内可见,并且在会话结束时自动删除。...

    Oracle 临时表之临时表的应用问题

     临时表本质上是一种cache的表现形式,Oracle的临时表都是事先建好的,一旦用了临时表,存放的是和本会话相关的数据,没有人会傻乎乎地用临时表来保存本应该共享的数据。  with子查询实际上也是用了临时表,...

    C# 取ipv6地址(有临时地址时取临时Ipv6地址)

    本文将详细讲解如何利用C#来获取IPv4和IPv6地址,特别是当存在临时IPv6地址时如何优先选择这些地址。 首先,我们需要了解IPv4和IPv6的基本概念。IPv4是第四版互联网协议,它使用32位地址,最多可以表示约42亿个不同...

    Mapgis临时备份文件清除

    在日常使用过程中,MapGIS会自动生成一些临时备份文件,这些文件通常带有“~”符号作为前缀,以保护用户在操作时的数据安全。然而,随着时间的推移,这些临时备份文件可能会占用大量的硬盘空间,影响计算机性能。...

    临时邮箱在线生成器 可循环接收邮件

    临时邮箱是一种短期、一次性使用的电子邮箱地址,常用于保护个人隐私、避免垃圾邮件或测试目的。在线生成器是提供这种服务的平台,用户无需注册,只需简单操作即可获得临时邮箱地址。下面将详细介绍临时邮箱在线生成...

    无法更新临时表的问题

    在IT领域,尤其是在数据库编程中,遇到“无法更新临时表”的问题通常是由于多种原因引起的。在本案例中,用户在Visual FoxPro(VFP)环境中遇到了这个问题,这是一款早期的数据库开发工具,它允许开发者创建数据库...

    SQL Server中关于临时表概念及创建和插入数据等问题

    SQL Server 中的临时表概念、创建和插入数据等问题 SQL Server 中的临时表概念是指名称以井号 (#) 开头的表,如果当用户断开连接时没有除去临时表,SQL Server 将自动除去临时表。临时表有两种类型:本地临时表和...

    主流数据库中临时表的使用

    主流数据库中临时表的使用 在主流数据库中,临时表是一种特殊类型的表,它们是临时存储数据的容器。临时表可以在不同的数据库管理系统中使用,本文将对 MS SQLSERVER、Oracle 和 DB2 中的临时表进行介绍。 MS SQL ...

    javascript获取浏览器临时目录

    ### JavaScript 获取浏览器临时目录知识点详解 #### 一、概述 在Web开发中,有时需要获取浏览器的临时目录以便进行文件操作或数据缓存等任务。然而,由于浏览器安全策略的限制,JavaScript直接获取本地文件系统...

    ORACLE中临时表

    Oracle中的临时表是一种特殊的数据结构,用于存储会话或事务期间的数据,这些数据仅对当前会话可见,并在特定条件下自动清除。Oracle提供两种类型的临时表:事务型和会话型。 事务型临时表在事务开始时创建,插入的...

    sql server触发器中自动生成的临时表

    SQL Server 触发器中自动生成的临时表 SQL Server 触发器是一种强大的工具,用于自动执行某些操作,以响应数据库中的变化。其中,系统自动生成的临时表是触发器中一个重要的组成部分。今天,我们将详细介绍 SQL ...

    按临时实体类型flexsim

    在FlexSim中,“临时实体类型”(Temporary Entity Type)是一个关键概念,它允许用户自定义临时实体,以适应特定的模拟场景。这些实体可以在运行时动态创建和销毁,根据模型的需求来变化,为建模提供了极大的灵活性...

    vb, 获取临时文件,临时文件提取

    在VB(Visual Basic)编程环境中,获取和处理临时文件是一项常见的任务,特别是在开发涉及数据存储、备份或系统恢复的应用程序时。临时文件通常用于存放临时数据,这些数据可能在程序运行过程中产生,但不需要长期...

    Oracle临时表空间满的解决步骤

    解决 Oracle 临时表空间满的问题需要通过查看当前数据库的默认临时表空间、查看当前临时表空间的大小、创建新的临时表空间、将新建的临时表空间设置为数据库的默认临时表空间、删除原来的临时表空间、创建新的临时表...

    java 在指定的目录下创建多个临时文件

    在Java编程语言中,创建多个临时文件是常见的需求,特别是在测试、数据处理或者临时存储一些信息时。要实现这个功能,我们需要使用Java的`java.io.File`类和`java.nio.file.Files`类提供的方法。接下来,我们将详细...

Global site tag (gtag.js) - Google Analytics