汽车销售管理系统
一、项目介绍
基于springboot+vue的前后端分离汽车销售管理系统
主要技术:Java,Springboot,mybatis,mysql,Vue
针对汽车销售提供客户信息、车辆信息、订单信息、销售人员管理、财务报表等功能,提供经理和销售两种角色进行管理。
一、销售人员功能模块介绍
1、本月销售额统计 2、本月销量统计 3、销售管理(新订单、销售订单、订单详情) 4、客户管理(添加客户、客户信息) 5、库存管理 6、个人月报 7、个人信息
二、管理人员功能模块介绍
1、本月销售额统计 2、本月销量统计 3、销售管理(新订单、销售订单、订单详情) 4、客户管理(添加客户、客户信息) 5、库存管理(添加库存、车辆库存) 6、财务报表(员工报表、销量报表、个人月报表) 7、员工管理(添加员工,员工信息)
二、系统运行界面图
三、系统部分功能截图
四、部分代码展示
package com.gxyan.service.impl;
import com.gxyan.common.ServerResponse;
import com.gxyan.dao.OrderDetailsMapper;
import com.gxyan.dao.OrderMapper;
import com.gxyan.service.IChartService;
import com.gxyan.vo.EmpChart;
import com.gxyan.vo.IndexSales;
import com.gxyan.vo.SalesChart;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;
/**
* @author gxyan
* @date 2019/1/13 9:19
*/
@Slf4j
@Service
public class ChartServiceImpl implements IChartService {
@Autowired
private OrderMapper orderMapper;
@Autowired
private OrderDetailsMapper detailsMapper;
@Override
public ServerResponse getEmpChart(String date) {
List <EmpChart> chartData = orderMapper.selectChartByDate(date);
if (chartData != null) {
return ServerResponse.createBySuccess(chartData);
}
return ServerResponse.createByErrorMessage("木有数据哦");
}
@Override
public ServerResponse getIndexChart() {
List <EmpChart> chartData = orderMapper.selectYesterdayChart();
if (chartData != null) {
return ServerResponse.createBySuccess(chartData);
}
return ServerResponse.createByErrorMessage("木有数据哦");
}
@Override
public ServerResponse getSaleNum() {
int num = detailsMapper.selectYesterdayNum();
return ServerResponse.createBySuccess(num);
}
@Override
public ServerResponse getSalesChart(String start, String end) {
List<SalesChart> salesCharts = detailsMapper.selectSalesChart(start, end);
if (salesCharts != null) {
return ServerResponse.createBySuccess(salesCharts);
}
return ServerResponse.createByErrorMessage("木有数据哦");
}
@Override
public ServerResponse getIndexSales(Integer id) {
IndexSales indexSales = detailsMapper.selectIndexSales(id);
if (indexSales != null) {
return ServerResponse.createBySuccess(indexSales);
}
return ServerResponse.createByErrorMessage("木有数据哦");
}
@Override
public ServerResponse getEmpSalesChart(Integer id, String date) {
List <EmpChart> chartData = detailsMapper.selectEmpChart(id, date);
if (chartData != null) {
return ServerResponse.createBySuccess(chartData);
}
return ServerResponse.createByErrorMessage("木有数据哦");
}
}
package com.gxyan.service.impl;
import com.github.pagehelper.PageHelper;
import com.gxyan.common.ServerResponse;
import com.gxyan.dao.CustomerMapper;
import com.gxyan.pojo.Customer;
import com.gxyan.service.ICustomerService;
import com.gxyan.vo.CustomerQuery;
import com.gxyan.vo.ListVo;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Service;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.List;
/**
* @author gxyan
* @date 2019/1/6 10:07
*/
@Slf4j
@Service
public class CustomerServiceImpl implements ICustomerService {
@Autowired
private CustomerMapper customerMapper;
@Override
public ServerResponse addCustomer(Customer customer) {
customer.setId(createCustomerId());
int resultCount = customerMapper.insert(customer);
if (resultCount != 0) {
return ServerResponse.createBySuccess();
}
return ServerResponse.createByErrorMessage("添加失败");
}
@Override
public ServerResponse getList(CustomerQuery customerQuery) {
List<Customer> list = PageHelper.startPage(customerQuery.getPage(), customerQuery.getLimit()).doSelectPage(()-> customerMapper.selectSelective(customerQuery));
if (list != null) {
ListVo listVo = new ListVo();
listVo.setItems(list);
listVo.setTotal(PageHelper.count(()->customerMapper.selectSelective(customerQuery)));
return ServerResponse.createBySuccess(listVo);
}
return ServerResponse.createByErrorMessage("获取客户列表失败");
}
@Override
public ServerResponse updateCustomer(Customer customer) {
int resultCount = customerMapper.updateByPrimaryKey(customer);
if (resultCount != 0) {
return ServerResponse.createBySuccess();
}
log.error(customer.toString());
return ServerResponse.createByErrorMessage("更新失败");
}
/**
* 客户编号
* 格式为:yyMMdd 加 五位递增的数字,数字每天重置为1
* @return
*/
private Long createCustomerId() {
SimpleDateFormat dateFormat = new SimpleDateFormat("yyMMdd");
String format = dateFormat.format(new Date()) + "10000";
return Long.valueOf(format) + (num++);
}
private int num = 1;
@Scheduled(cron="0 0 0 * * ?")
private void clearNum() {
num = 1;
}
}
package com.gxyan.controller;
import com.gxyan.common.ServerResponse;
import com.gxyan.pojo.Customer;
import com.gxyan.service.IChartService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.propertyeditors.CustomDateEditor;
import org.springframework.web.bind.WebDataBinder;
import org.springframework.web.bind.annotation.InitBinder;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
/**
* @author gxyan
* @date 2019/1/12 20:54
*/
@RestController
@RequestMapping("chart")
public class ChartController {
@Autowired
private IChartService chartService;
/**
* 获取 全部员工的月销量报表 数据
* @param date
* @return
*/
@RequestMapping(value = "getEmpChart", method = RequestMethod.GET)
public ServerResponse getEmpChart(String date) {
return chartService.getEmpChart(date);
}
/**
* 获取经理主页 昨日销量报表 数据
* @return
*/
@RequestMapping(value = "getIndexChart", method = RequestMethod.GET)
public ServerResponse getIndexChart() {
return chartService.getIndexChart();
}
/**
* 获取经理主页 昨日销量
* @return
*/
@RequestMapping(value = "getSaleNum", method = RequestMethod.GET)
public ServerResponse getSaleNum() {
return chartService.getSaleNum();
}
/**
* 获取 销售报表 数据
* @param start
* @param end
* @return
*/
@RequestMapping(value = "getSalesChart", method = RequestMethod.GET)
public ServerResponse getSalesChart(String start, String end) {
return chartService.getSalesChart(start, end);
}
/**
* 获取员工主页 本月销售额 数据
* @param id
* @return
*/
@RequestMapping(value = "getIndexSales", method = RequestMethod.GET)
public ServerResponse getIndexSales(Integer id) {
return chartService.getIndexSales(id);
}
@RequestMapping(value = "getEmpSalesChart", method = RequestMethod.GET)
public ServerResponse getEmpSalesChart(Integer id, String date) {
return chartService.getEmpSalesChart(id, date);
}
}
五、底部获取源码(9.9¥带走)
有问题,或者需要协助调试运行项目的也可以