Java-单机版的书店管理系统(练习设计模块和思想_系列 八 )

本系列前面博客的链接:

Java-单机版的书店管理系统(练习设计模块和思想_系列 七 )
http://blog.csdn.net/qq_26525215/article/details/51190696

Java-单机版的书店管理系统(练习设计模块和思想_系列 六 )
http://blog.csdn.net/qq_26525215/article/details/51169277

Java-单机版的书店管理系统(练习设计模块和思想_系列 五 )
http://blog.csdn.net/qq_26525215/article/details/51136848

Java-单机版的书店管理系统(练习设计模块和思想_系列 四(2) ):
http://blog.csdn.net/qq_26525215/article/details/51117135

Java-单机版的书店管理系统(练习设计模块和思想_系列 四(1) ):
http://blog.csdn.net/qq_26525215/article/details/51116429

Java-单机版的书店管理系统(练习设计模块和思想_系列 三 ):
http://blog.csdn.net/qq_26525215/article/details/51099202

Java-单机版的书店管理系统(练习设计模块和思想_系列 二 ):
http://blog.csdn.net/qq_26525215/article/details/51089734

Java-单机版的书店管理系统(练习设计模块和思想_系列 一 ):
http://blog.csdn.net/qq_26525215/article/details/51073546

介绍:

完成了销售模块。

因为销售模块和进货模块惊人的相似,
我就利用代码拷贝技术,直接拷贝进货模块的代码了,只是改了类名和变量名。
这对于以后在公司开发项目是有好处的,
能节省大量的时间!而且不容易出错。大家如果以后开发项目可以学学这种拷贝代码,修改代码名称类名来完成功能几乎一样的模块。

销售模块源代码:

值对象封装OutMainModel:

package cn.hncu.bookStore.out.vo;

import java.io.Serializable;

import cn.hncu.bookStore.util.DateUtil;

/**
 * 销售管理值对象封装
 * @author 陈浩翔
 *
 * @version 1.0
 */
public class OutMainModel implements Serializable, Comparable<OutMainModel>{
    //销售单编号
    private String uuid;
    //销售时间
    private long outDate;
    //销售人员编号
    private String outUserId;

    /* 
       如果某个字段是外键,同时又需要在当前表中相应表现层显示出用户能看得懂
     的信息,则需要补一个专用于信息显示(给用户看)的字段。
     */
    private String outUserName;

    public String getOutUserName() {
        return outUserName;
    }

    public void setOutUserName(String outUserName) {
        this.outUserName = outUserName;
    }

    /**
     * 
     * @return ---返回销售单编号(String型)
     */
    public String getUuid() {
        return uuid;
    }

    /**
     * 
     * @param uuid---设置销售单编号(String型)
     */
    public void setUuid(String uuid) {
        this.uuid = uuid;
    }

    /**
     * 
     * @return---返回销售时间(long型)
     */
    public long getOutDate() {
        return outDate;
    }

    /**
     * 
     * @param outDate---设置销售时间(long型)
     */
    public void setOutDate(long outDate) {
        this.outDate = outDate;
    }

    /**
     * 
     * @return---返回销售人员编号(String型)
     */
    public String getOutUserId() {
        return outUserId;
    }

    /**
     * 
     * @param outUserId---设置销售人员编号(String型)
     */
    public void setOutUserId(String outUserId) {
        this.outUserId = outUserId;
    }

    @Override
    public int hashCode() {
        final int prime = 31;
        int result = 1;
        result = prime * result + ((uuid == null) ? 0 : uuid.hashCode());
        return result;
    }

    @Override
    public boolean equals(Object obj) {
        if (this == obj)
            return true;
        if (obj == null)
            return false;
        if (getClass() != obj.getClass())
            return false;
        OutMainModel other = (OutMainModel) obj;
        if (uuid == null) {
            if (other.uuid != null)
                return false;
        } else if (!uuid.equals(other.uuid))
            return false;
        return true;
    }

    @Override
    public String toString() {
        return uuid + ", " + outUserName
                + ", " + DateUtil.long2String(outDate);
    }

    @Override
    public int compareTo(OutMainModel o) {
        return Integer.parseInt(uuid)-Integer.parseInt(o.uuid);
    }
}

值对象查询封装OutMainQueryModel:

package cn.hncu.bookStore.out.vo;

/**
 * 销售查询值对象封装
 * @author 陈浩翔
 *
 * @version 1.0
 */
public class OutMainQueryModel extends OutMainModel {

    //需要查询的最大时间
    private long outDate2;

    /**
     * 
     * @return---需要查询的最大时间值
     */
    public long getOutDate2() {
        return outDate2;
    }

    /**
     * 
     * @param outDate2---设置需要查询的最大时间
     */
    public void setOutDate2(long inDate2) {
        this.outDate2 = outDate2;
    }

}

销售明细值对象封装OutDetailModel:

package cn.hncu.bookStore.out.vo;

import java.io.Serializable;

/**
 * 销售明细管理的值对象封装
 * @author 陈浩翔
 *
 * @version 1.0
 */
public class OutDetailModel implements Serializable{
    //销售明细编号
    private String uuid;
    //销售单编号
    private String outId;
    //图书编号
    private String bookId;
    //销售数量
    private int sumNum;
    //销售总金额
    private double sumMoney;

    //为把书名显示给用户看,给bookUuid添加一个bookName属性
    private String bookName;



    public String getBookName() {
        return bookName;
    }
    public void setBookName(String bookName) {
        this.bookName = bookName;
    }
    public String getUuid() {
        return uuid;
    }
    public void setUuid(String uuid) {
        this.uuid = uuid;
    }
    public String getOutId() {
        return outId;
    }
    public void setOutId(String outId) {
        this.outId = outId;
    }
    public String getBookId() {
        return bookId;
    }
    public void setBookId(String bookId) {
        this.bookId = bookId;
    }
    public int getSumNum() {
        return sumNum;
    }
    public void setSumNum(int sumNum) {
        this.sumNum = sumNum;
    }
    public double getSumMoney() {
        return sumMoney;
    }
    public void setSumMoney(double sumMoney) {
        this.sumMoney = sumMoney;
    }


    @Override
    public int hashCode() {
        final int prime = 31;
        int result = 1;
        result = prime * result + ((uuid == null) ? 0 : uuid.hashCode());
        return result;
    }
    @Override
    public boolean equals(Object obj) {
        if (this == obj)
            return true;
        if (obj == null)
            return false;
        if (getClass() != obj.getClass())
            return false;
        OutDetailModel other = (OutDetailModel) obj;
        if (uuid == null) {
            if (other.uuid != null)
                return false;
        } else if (!uuid.equals(other.uuid))
            return false;
        return true;
    }
    @Override
    public String toString() {
        return uuid +", "+bookName + ", " + sumNum
                + "本, " + sumMoney + "元";
    }





}

销售明细查询值对象封装OutDetailQueryModel:

package cn.hncu.bookStore.out.vo;

/**
 * 销售明细查询值对象封装
 * @author 陈浩翔
 *
 * @version 1.0
 */
public class OutDetailQueryModel extends OutDetailModel {

    //需要查询的最大销售数量
    private int sumNum2;
    //需要查询的最大销售金额
    private double sumMoney2;

    /**
     * 
     * @return---返回需要查询的最大销售数量
     */
    public int getSumNum2() {
        return sumNum2;
    }
    /**
     * 
     * @param sumNum2---设置需要查询的最大销售数量
     */
    public void setSumNum2(int sumNum2) {
        this.sumNum2 = sumNum2;
    }

    /**
     * 
     * @return---返回需要查询的最大销售金额
     */
    public double getSumMoney2() {
        return sumMoney2;
    }

    /**
     * 
     * @param sumMoney2---设置需要查询的最大销售金额
     */
    public void setSumMoney2(double sumMoney2) {
        this.sumMoney2 = sumMoney2;
    }

}

数据层接口OutMainDao:

package cn.hncu.bookStore.out.dao.dao;

import java.util.List;

import cn.hncu.bookStore.out.vo.OutMainModel;
import cn.hncu.bookStore.out.vo.OutMainQueryModel;

/**
 * 销售管理数据层接口
 * 
 * @author 陈浩翔
 * 
 * @version 1.0
 */
public interface OutMainDao {

    /**
     * 创建一个销售数据对象
     * @param outMain---需要创建的销售数据对象
     * @return---true 表示创建成功,false 表示创建失败
     */
    public boolean create(OutMainModel outMain);

    /**
     * 删除一个销售数据对象
     * @param uuid---销售单的编号-唯一的
     * @return---true表示删除成功, false表示删除失败
     */
    public boolean delete(String uuid);

    /**
     * 修改一个销售数据的对象
     * @param outMain---需要修改的销售管理对象
     * @return---true表示修改成功,false表示修改失败
     */
    public boolean update(OutMainModel outMain);

    /**
     * 根据销售单编号,得到销售对象的其他信息资料
     * @param uuid---销售单编号
     * @return---该对象的其他其他信息资料
     */
    public OutMainModel getSingle(String uuid);

    /**
     * 
     * @return---所有的销售管理对象信息
     */
    public List getAll();

    /**
     * 查找销售管理对象
     * @param imqm---查找条件!
     * @return---满足查找条件的所有OutMainModel对象
     */
    public List getbyCondition(OutMainQueryModel omqm);
}

数据层接口OutDetailDao:

package cn.hncu.bookStore.out.dao.dao;

import java.util.List;

import cn.hncu.bookStore.out.vo.OutDetailModel;
import cn.hncu.bookStore.out.vo.OutDetailQueryModel;

/**
 * 销售明细管理数据层接口
 * @author 陈浩翔
 *
 * @version 1.0
 */
public interface OutDetailDao {
    /**
     * 创建一个销售明细数据对象
     * @param outMain---需要创建的销售明细数据对象
     * @return---true 表示创建成功,false 表示创建失败
     */
    public boolean create(OutDetailModel outDetail);

    /**
     * 删除一个销售明细数据对象
     * @param uuid---销售明细单的编号-唯一的
     * @return---true表示删除成功, false表示删除失败
     */
    public boolean delete(String uuid);

    /**
     * 修改一个销售明细数据的对象
     * @param outMain---需要修改的销售管理明细对象
     * @return---true表示修改成功,false表示修改失败
     */
    public boolean update(OutDetailModel outDetail);

    /**
     * 根据销售明细单编号,得到销售明细对象的其他信息资料
     * @param uuid---销售明细单编号
     * @return---该对象的其他其他信息资料
     */
    public OutDetailModel getSingle(String uuid);

    /**
     * 
     * @return---所有的销售明细管理对象信息
     */
    public List getAll();

    /**
     * 查找销售明细管理对象
     * @param omqm---查找条件!
     * @return---满足查找条件的所有OutDetailModel对象
     */
    public List getbyCondition(OutDetailQueryModel odqm);
}

数据层实现类OutMainDaoSerImpl:

package cn.hncu.bookStore.out.dao.impl;

import java.util.ArrayList;
import java.util.List;

import cn.hncu.bookStore.out.dao.dao.OutMainDao;
import cn.hncu.bookStore.out.vo.OutMainModel;
import cn.hncu.bookStore.out.vo.OutMainQueryModel;
import cn.hncu.bookStore.util.FileIoUtil;
import cn.hncu.bookStore.util.StringComparison;

/**
 * 销售管理的实现类
 * @author 陈浩翔
 *
 * @version 1.0
 */
public class OutMainDaoSerImpl implements OutMainDao {

    private final String FILE_NAME = "OutMain.txt";
    @Override
    public boolean create(OutMainModel outMain) {
        List list = FileIoUtil.readFormFile(FILE_NAME);
        for(OutMainModel model:list){
            if(model.getUuid().equals(outMain.getUuid())){//存在,则不能添加
                return false;
            }
        }
        list.add(outMain);
        FileIoUtil.write2file(list, FILE_NAME);
        return true;
    }

    @Override
    public boolean delete(String uuid) {
        List list = FileIoUtil.readFormFile(FILE_NAME);
        for(OutMainModel model:list){
            if(model.getUuid().equals(uuid)){//存在,则删除
                list.remove(model);
                FileIoUtil.write2file(list, FILE_NAME);
                return true;
            }
        }
        return false;
    }

    @Override
    public boolean update(OutMainModel outMain) {
        List list = FileIoUtil.readFormFile(FILE_NAME);
        for(int i=0;iif(model.getUuid().equals(outMain.getUuid())){//存在,则修改
                list.set(i, outMain);
                FileIoUtil.write2file(list, FILE_NAME);
                return true;
            }
        }
        return false;
    }

    @Override
    public OutMainModel getSingle(String uuid) {
        List list = FileIoUtil.readFormFile(FILE_NAME);
        for(OutMainModel model:list){
            if(model.getUuid().equals(uuid)){//存在,则返回
                return model;
            }
        }
        return null;
    }

    @Override
    public List getAll() {
        return FileIoUtil.readFormFile(FILE_NAME);
    }

    @Override
    public List getbyCondition(OutMainQueryModel omqm) {
        List lists = FileIoUtil.readFormFile(FILE_NAME);
        List results = new ArrayList();
        for(OutMainModel model : lists){



            if(!StringComparison.stringEquals( model.getUuid(),omqm.getUuid())){
                continue;
            }

            if(!StringComparison.stringEquals(model.getOutUserId(), omqm.getOutUserId())){
                continue;
            }
            if(omqm.getOutDate()>0){
                if(model.getOutDate()continue;
                }
            }
            if(omqm.getOutDate2()>0){
                if(model.getOutDate()>omqm.getOutDate2()){
                    continue;
                }
            }
            results.add(model);
        }
        return results;
    }

}

数据层实现类OutDetailDaoSerImpl:

package cn.hncu.bookStore.out.dao.impl;

import java.util.ArrayList;
import java.util.List;

import cn.hncu.bookStore.out.dao.dao.OutDetailDao;
import cn.hncu.bookStore.out.dao.factory.OutDetailDaoFactory;
import cn.hncu.bookStore.out.vo.OutDetailModel;
import cn.hncu.bookStore.out.vo.OutDetailQueryModel;
import cn.hncu.bookStore.util.FileIoUtil;
import cn.hncu.bookStore.util.StringComparison;

/**
 * 销售明细的实现类
 * @author 陈浩翔
 *
 * @version 1.0
 */
public class OutDetailDaoSerImpl implements OutDetailDao{
    //销售明细数据的存储的文件名
    private final String FILE_NAME = "OutDetail.txt";

    @Override
    public boolean create(OutDetailModel outDetail) {
        List lists = FileIoUtil.readFormFile(FILE_NAME);

        for(OutDetailModel model: lists){
            //已经存在这个Uuid,不能添加
            if(model.getUuid().equals(outDetail.getUuid())){
                return false;
            }
        }

        lists.add(outDetail);
        FileIoUtil.write2file(lists, FILE_NAME);
        return true;
    }

    @Override
    public boolean delete(String uuid) {
        List list = FileIoUtil.readFormFile(FILE_NAME);
        for(OutDetailModel model: list){
            //存在,就删除
            if(model.getUuid().equals(uuid)){
                list.remove(model);
                FileIoUtil.write2file(list, FILE_NAME);
                return true;
            }
        }
        return false;
    }

    @Override
    public boolean update(OutDetailModel outDetail) {
        List list  = FileIoUtil.readFormFile(FILE_NAME);
        for(int i=0;i//找到了,就修改
            if(list.get(i).getUuid().equals(outDetail.getUuid())){
                list.set(i, outDetail);
                FileIoUtil.write2file(list, FILE_NAME);
                return true;
            }
        }
        return false;
    }

    @Override
    public OutDetailModel getSingle(String uuid) {
        List list = FileIoUtil.readFormFile(FILE_NAME);
        for(OutDetailModel model : list){
            //找到了,就返回
            if(model.getUuid().equals(uuid)){
                return model;
            }
        }
        return null;
    }

    @Override
    public List getAll() {
        return FileIoUtil.readFormFile(FILE_NAME);
    }

    @Override
    public List getbyCondition(OutDetailQueryModel odqm) {
        List lists = getAll();
        List resulits = new ArrayList();
        for(OutDetailModel model:lists){

            if(!StringComparison.stringEquals(model.getUuid(), odqm.getUuid())){
                continue;
            }

            if(!StringComparison.stringEquals(model.getOutId(), odqm.getOutId())){
                continue;
            }

            if(!StringComparison.stringEquals(model.getBookId(), odqm.getBookId())){
                continue;
            }

            if(odqm.getSumNum()>0){
                if(model.getSumNum()continue;
                }
            }
            if(odqm.getSumNum2()>0){
                if(model.getSumNum()>odqm.getSumNum2()){
                    continue;
                }
            }

            if(odqm.getSumMoney()>0){
                if(model.getSumMoney()continue;
                }
            }
            if(odqm.getSumMoney2()>0){
                if(model.getSumMoney()>odqm.getSumMoney2()){
                    continue;
                }
            }

            resulits.add(model);
        }
        return resulits;
    }

}

数据层工厂类OutMainDaoFactory:

package cn.hncu.bookStore.out.dao.factory;

import cn.hncu.bookStore.out.dao.dao.OutMainDao;
import cn.hncu.bookStore.out.dao.impl.OutMainDaoSerImpl;

/**
 * 工厂方法---new 一个销售实现类
 * @author 陈浩翔
 * @version 1.0
 */
public class OutMainDaoFactory {

    public static OutMainDao getOutMainDao(){
        return new OutMainDaoSerImpl();
    }
}

数据层工厂类OutDetailDaoFactory:

package cn.hncu.bookStore.out.dao.factory;

import cn.hncu.bookStore.out.dao.dao.OutDetailDao;
import cn.hncu.bookStore.out.dao.impl.OutDetailDaoSerImpl;

/**
 * 工厂方法----new 一个销售明细的实现类
 * @author 陈浩翔
 *
 * @version 1.0
 */
public class OutDetailDaoFactory {

    public static OutDetailDao getOutDetailDao(){
        return new OutDetailDaoSerImpl();
    }
}

逻辑层接口OutMainEbi:

package cn.hncu.bookStore.out.business.ebi;

import java.util.List;
import java.util.Map;

import cn.hncu.bookStore.out.vo.OutMainQueryModel;
import cn.hncu.bookStore.out.vo.OutDetailModel;
import cn.hncu.bookStore.out.vo.OutDetailQueryModel;
import cn.hncu.bookStore.out.vo.OutMainModel;

/**
 * 
 * @author 陈浩翔
 * @version 1.0
 */
public interface OutMainEbi {

    /**
     * 创建一个销售模块数据-
     * @param inMain---销售数据
     * @param outDetails---销售明细数据
     * @return---返回true表示创建成功,false表示创建失败
     */
    public abstract boolean create(OutMainModel inMain,List outDetails);

    /**
     * 
     * @return---返回所有的销售模块(包括销售明细)的集合
     */
    public abstract Map> getAll();

    /**
     * 
     * @param omqm---销售管理需要查找的条件
     * @param idqm---销售明细需要查找的条件
     * @return---满足条件的所有销售数据的Map集合
     */
    public abstract Map> getByCondition(OutMainQueryModel omqm,OutDetailQueryModel odqm);

}

逻辑层实现类OutMainEbo:

package cn.hncu.bookStore.out.business.ebo;

import java.util.List;
import java.util.Map;
import java.util.TreeMap;

import cn.hncu.bookStore.book.business.ebi.BookEbi;
import cn.hncu.bookStore.book.business.factory.BookEbiFactory;
import cn.hncu.bookStore.common.UuidModelConstance;
import cn.hncu.bookStore.common.uuid.dao.dao.UuidDao;
import cn.hncu.bookStore.common.uuid.dao.factory.UuidDaoFactory;
import cn.hncu.bookStore.out.business.ebi.OutMainEbi;
import cn.hncu.bookStore.out.dao.dao.OutDetailDao;
import cn.hncu.bookStore.out.dao.dao.OutMainDao;
import cn.hncu.bookStore.out.dao.factory.OutDetailDaoFactory;
import cn.hncu.bookStore.out.dao.factory.OutMainDaoFactory;
import cn.hncu.bookStore.out.vo.OutDetailModel;
import cn.hncu.bookStore.out.vo.OutDetailQueryModel;
import cn.hncu.bookStore.out.vo.OutMainModel;
import cn.hncu.bookStore.out.vo.OutMainQueryModel;

/**
 * 
 * @author 陈浩翔
 *
 * @version 1.0
 */
public class OutMainEbo implements OutMainEbi{
    //注入dao

    OutMainDao outMainDao = OutMainDaoFactory.getOutMainDao();
    OutDetailDao outDetailDao = OutDetailDaoFactory.getOutDetailDao();
    UuidDao uuidDao = UuidDaoFactory.getUuidDao();
    BookEbi bookEbi = BookEbiFactory.getBookEbi();

    @Override
    public boolean create(OutMainModel outMain, List outDetails) {
        //////////1存储outMain信息///////////
        //补全outMain中的数据
        //需要:inUuid,inDate,inUserUuid   已组织:inUserUuid
        //还缺(需补):inUuid,inDate
        String outUuid = uuidDao.getNextUuid(UuidModelConstance.OUT_MAIN);
        outMain.setUuid(outUuid);
        outMain.setOutDate(System.currentTimeMillis());
        outMainDao.create(outMain);

         //////////2存储inDetail信息///////////
        for(OutDetailModel model:outDetails){
            //补全每一个inDetail中的数据
            //需要:inDetailUuid,outMainUuid,bookUuid,sumNum,sumMoney   已组织:bookUuid,sumNum
            //还缺(需补):inDetailUuid,outMainUuid,sumMoney
            model.setUuid(uuidDao.getNextUuid(UuidModelConstance.OUT_DETAIL));
            model.setOutId(outUuid);

            double sumMoney = model.getSumNum() * bookEbi.getSingle(model.getBookId()).getSalePrice();
            model.setSumMoney(sumMoney);
            outDetailDao.create(model);
        }
        return true;
    }

    @Override
    public Map> getAll() {
        Map> map = new TreeMap>();

        List outMains = outMainDao.getAll();

        for(OutMainModel outMain: outMains ){
            //查询条件值对象的创建
            OutDetailQueryModel odqm = new OutDetailQueryModel();
            String inUuid = outMain.getUuid();
            odqm.setOutId(inUuid);

            List details = outDetailDao.getbyCondition(odqm);

            map.put(outMain, details);
        }

        return map;
    }

    @Override
    public Map> getByCondition(
            OutMainQueryModel imqm, OutDetailQueryModel odqm) {
        Map> map = new TreeMap>();

        List list = outMainDao.getbyCondition(imqm);

        for(OutMainModel outMain : list){
            odqm.setOutId(outMain.getUuid());

            List details = outDetailDao.getbyCondition(odqm);
            if(details.size()!=0){
                map.put(outMain, details);
            }
        }

        return map;
    }

}

逻辑层工厂方法OutMainEbiFactory:

package cn.hncu.bookStore.out.business.factory;

import cn.hncu.bookStore.out.business.ebi.OutMainEbi;
import cn.hncu.bookStore.out.business.ebo.OutMainEbo;

/**
 * 工厂方法
 * @author 陈浩翔
 *
 * @version 1.0
 */
public class OutMainEbiFactory {
    /**
     * 
     * @return---new一个逻辑层的接口的实例
     */
    public static OutMainEbi getOutMainEbi(){
        return new OutMainEbo();
    }
}

表现层的代码我就不直接这样写了。。。
表现层的大部分代码是自动生成的,只有监听和初始化box是自己写的。

其他所有代码的百度云链接:
http://pan.baidu.com/s/1jH7RNQu

其他系列也是这样,我在写博客时,我都把我目前写到哪了的所有代码都上传了的。有兴趣的,可以去看看。有bug什么的,欢迎评论。

你可能感兴趣的:(Java-单机版的书店管理系统(练习设计模块和思想_系列 八 ))